您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)ASP.NET新增時(shí)多字段取值的問(wèn)題怎么辦,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
ASP.NET 開(kāi)發(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了!
關(guān)于“ASP.NET新增時(shí)多字段取值的問(wèn)題怎么辦”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。