ASP.NET 開發(fā)人員在卡發(fā)時(shí)經(jīng)常會(huì)碰到一個(gè)情況,就是新增的頁面中字段太多,在點(diǎn)擊保存的時(shí)候需要一個(gè)一個(gè)的賦值實(shí)體或者構(gòu)建SQL語句去保存。這樣不僅浪費(fèi)體力還需要占用大量的文本行控件去寫代碼。經(jīng)過構(gòu)思是否可以使用一種更方便的辦法去解決呢?提高代碼的內(nèi)聚性。
1.思路
我們知道一般新增頁面最多的就是一大堆文本框讓用戶輸入內(nèi)容,然后點(diǎn)擊保存按鈕進(jìn)行提交將數(shù)據(jù)持久化到數(shù)據(jù)庫。
在點(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);
}
如果頁面的字段特別多就會(huì)導(dǎo)致需要些很多的賦值語句。所以在多字段的情況下我們可以去遍歷頁面上的控件去賦值,然后將結(jié)果放入集合中去提交持久化數(shù)據(jù)。
按鈕提交時(shí)間代碼:
protected void Button2_Click(object sender, EventArgs e)
{
Dictionarystring, string> entityDic = new Dictionarystring, 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è)字典集合用來存放字段文本框中的值,key 存列明,value存實(shí)際輸入的值
2. 循環(huán)遍歷容器中的控件,給集合添加節(jié)點(diǎn),key為控件的ID也就是數(shù)據(jù)庫的列明,value是實(shí)際輸入的值,也就是需要新增到數(shù)據(jù)庫的值
3.調(diào)用保存方法保存數(shù)據(jù)
問題:
這個(gè)時(shí)候可能有人會(huì)問了,將頁面上的控件名字跟數(shù)據(jù)庫的字段名如果保持一致是不是太不安全啦?解決這個(gè)問題的辦法,就是將數(shù)據(jù)庫字段一自己自定義的一種算法加密顯示在頁面,在封裝一個(gè)TextBox的擴(kuò)展方法,這個(gè)方法用來解析這個(gè)算法,返回正確的列明,代碼如下:
public static class TextBoxEx
{
public static string GetMapColumnsName(this TextBox my)
{
string myColumnsName = my.ID;
//將來文本ID可以為了安全存為加密過的值 這里可以負(fù)責(zé)解密
return myColumnsName;
}
}
這樣就可以用很少的代碼來解決,新增或者編輯時(shí),頁面的字段太多的問題啦!
2.應(yīng)對需求的更變
現(xiàn)在我們?nèi)绻撁娴淖侄涡略隽?,或者減少了,我們可以不必就該,提交按鈕的事件,而是在頁面上新增或者刪除對應(yīng)的展示控件就行啦!
例如頁面有5個(gè)TextBox控件,如果需要加入一個(gè)我們只需在頁面上多寫一個(gè)TextBox控件,將ID寫成自己加過密的文本,就OK了!
以上就是跟大家分享的如何解決ASP.NET新增時(shí)多字段取值問題的方法,希望大家仔細(xì)閱讀,運(yùn)用到自己的學(xué)習(xí)當(dāng)中。
您可能感興趣的文章:- Asp.Net+XML操作基類(修改,刪除,新增,創(chuàng)建)
- asp.net 多字段模糊查詢代碼
- asp.net中獲取新增加記錄的ID Access版
- ASP.NET服務(wù)器端控件RadioButtonList,DropDownList,CheckBoxList的取值、賦值用法