最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

如何解決ASP.NET新增時(shí)多字段取值的問(wèn)題

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:38:17
文檔

如何解決ASP.NET新增時(shí)多字段取值的問(wèn)題

如何解決ASP.NET新增時(shí)多字段取值的問(wèn)題:ASP.NET 開發(fā)人員在卡發(fā)時(shí)經(jīng)常會(huì)碰到一個(gè)情況,就是新增的頁(yè)面中字段太多,在點(diǎn)擊保存的時(shí)候需要一個(gè)一個(gè)的賦值實(shí)體或者構(gòu)建SQL語(yǔ)句去保存。這樣不僅浪費(fèi)體力還需要占用大量的文本行控件去寫代碼。經(jīng)過(guò)構(gòu)思是否可以使用一種更方便的辦法去解決呢?提高代碼的
推薦度:
導(dǎo)讀如何解決ASP.NET新增時(shí)多字段取值的問(wèn)題:ASP.NET 開發(fā)人員在卡發(fā)時(shí)經(jīng)常會(huì)碰到一個(gè)情況,就是新增的頁(yè)面中字段太多,在點(diǎn)擊保存的時(shí)候需要一個(gè)一個(gè)的賦值實(shí)體或者構(gòu)建SQL語(yǔ)句去保存。這樣不僅浪費(fèi)體力還需要占用大量的文本行控件去寫代碼。經(jīng)過(guò)構(gòu)思是否可以使用一種更方便的辦法去解決呢?提高代碼的

ASP.NET 開發(fā)人員在卡發(fā)時(shí)經(jīng)常會(huì)碰到一個(gè)情況,就是新增的頁(yè)面中字段太多,在點(diǎn)擊保存的時(shí)候需要一個(gè)一個(gè)的賦值實(shí)體或者構(gòu)建SQL語(yǔ)句去保存。這樣不僅浪費(fèi)體力還需要占用大量的文本行控件去寫代碼。經(jīng)過(guò)構(gòu)思是否可以使用一種更方便的辦法去解決呢?提高代碼的內(nèi)聚性。

 1.思路

 我們知道一般新增頁(yè)面最多的就是一大堆文本框讓用戶輸入內(nèi)容,然后點(diǎn)擊保存按鈕進(jìn)行提交將數(shù)據(jù)持久化到數(shù)據(jù)庫(kù)。

在點(diǎn)擊提交的時(shí)候傳統(tǒng)方式就是一個(gè)一個(gè)文本框的讀取賦值。

 HTML代碼如下:

<asp:TextBox ID="TextBox2" runat="server" Text="TextBox2" ></asp:TextBox> 
<asp:TextBox ID="TextBox3" runat="server" Text="TextBox3" ></asp:TextBox> 
<asp:Button ID="Button2" runat="server" Text="提交" onclick="Button2_Click" /> 

按鈕提交事件代碼:

protected void Button2_Click(object sender, EventArgs e) 
{ 
 string colName1 = TextBox2.Text;
 string colName2 = TextBox3.Text; 
 DataSave(colName1,colName2); 
} 


如果頁(yè)面的字段特別多就會(huì)導(dǎo)致需要些很多的賦值語(yǔ)句。所以在多字段的情況下我們可以去遍歷頁(yè)面上的控件去賦值,然后將結(jié)果放入集合中去提交持久化數(shù)據(jù)。

按鈕提交時(shí)間代碼:

protected void Button2_Click(object sender, EventArgs e) 
 { 
 Dictionary<string, string> entityDic = new Dictionary<string, string>(); 
 foreach (Control cnl in MyPanel.Controls) 
 { 
 if (cnl is TextBox) 
 { 
 TextBox tb = (cnl as TextBox); 
 entityDic.Add(tb.GetMapColumnsName(), tb.Text); 
 } 
 } 
 IDBHelper dbHelp = DataBaseProvider.Instance.GetDBHelper("orm"); 
 string result = dbHelp.DataSave(entityDic); 
} 

分析一下代碼:

1.首先定義一個(gè)字典集合用來(lái)存放字段文本框中的值,key 存列明,value存實(shí)際輸入的值

 2. 循環(huán)遍歷容器中的控件,給集合添加節(jié)點(diǎn),key為控件的ID也就是數(shù)據(jù)庫(kù)的列明,value是實(shí)際輸入的值,也就是需要新增到數(shù)據(jù)庫(kù)的值

3.調(diào)用保存方法保存數(shù)據(jù)

問(wèn)題:

這個(gè)時(shí)候可能有人會(huì)問(wèn)了,將頁(yè)面上的控件名字跟數(shù)據(jù)庫(kù)的字段名如果保持一致是不是太不安全啦?解決這個(gè)問(wèn)題的辦法,就是將數(shù)據(jù)庫(kù)字段一自己自定義的一種算法加密顯示在頁(yè)面,在封裝一個(gè)TextBox的擴(kuò)展方法,這個(gè)方法用來(lái)解析這個(gè)算法,返回正確的列明,代碼如下:

public static class TextBoxEx 
{ 
 public static string GetMapColumnsName(this TextBox my) 
 { 
 string myColumnsName = my.ID; 
 //將來(lái)文本ID可以為了安全存為加密過(guò)的值 這里可以負(fù)責(zé)解密 
 return myColumnsName; 
 } 
} 

這樣就可以用很少的代碼來(lái)解決,新增或者編輯時(shí),頁(yè)面的字段太多的問(wèn)題啦!

2.應(yīng)對(duì)需求的更變

 現(xiàn)在我們?nèi)绻?yè)面的字段新增了,或者減少了,我們可以不必就該,提交按鈕的事件,而是在頁(yè)面上新增或者刪除對(duì)應(yīng)的展示控件就行啦!

例如頁(yè)面有5個(gè)TextBox控件,如果需要加入一個(gè)我們只需在頁(yè)面上多寫一個(gè)TextBox控件,將ID寫成自己加過(guò)密的文本,就OK了!

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

如何解決ASP.NET新增時(shí)多字段取值的問(wèn)題

如何解決ASP.NET新增時(shí)多字段取值的問(wèn)題:ASP.NET 開發(fā)人員在卡發(fā)時(shí)經(jīng)常會(huì)碰到一個(gè)情況,就是新增的頁(yè)面中字段太多,在點(diǎn)擊保存的時(shí)候需要一個(gè)一個(gè)的賦值實(shí)體或者構(gòu)建SQL語(yǔ)句去保存。這樣不僅浪費(fèi)體力還需要占用大量的文本行控件去寫代碼。經(jīng)過(guò)構(gòu)思是否可以使用一種更方便的辦法去解決呢?提高代碼的
推薦度:
標(biāo)簽: 如何 怎么 新增
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top