溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ASP.NET新增時(shí)多字段取值的問(wèn)題怎么辦

發(fā)布時(shí)間:2021-02-05 15:02:07 來(lái)源:億速云 閱讀:140 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章將為大家詳細(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)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI