ASP.NET 开发人员在卡发时经常会碰到一个情况,就是新增的页面中字段太多,在点击保存的时候需要一个一个的赋值实体或者构建SQL语句去保存。这样不仅浪费体力还需要占用大量的文本行控件去写代码。经过构思是否可以使用一种更方便的办法去解决呢?提高代码的内聚性。
1.思路
我们知道一般新增页面最多的就是一大堆文本框让用户输入内容,然后点击保存按钮进行提交将数据持久化到数据库。
在点击提交的时候传统方式就是一个一个文本框的读取赋值。
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);
}
如果页面的字段特别多就会导致需要些很多的赋值语句。所以在多字段的情况下我们可以去遍历页面上的控件去赋值,然后将结果放入集合中去提交持久化数据。
按钮提交时间代码:
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.首先定义一个字典集合用来存放字段文本框中的值,key 存列明,value存实际输入的值
2. 循环遍历容器中的控件,给集合添加节点,key为控件的ID也就是数据库的列明,value是实际输入的值,也就是需要新增到数据库的值
3.调用保存方法保存数据
问题:
这个时候可能有人会问了,将页面上的控件名字跟数据库的字段名如果保持一致是不是太不安全啦?解决这个问题的办法,就是将数据库字段一自己自定义的一种算法加密显示在页面,在封装一个TextBox的扩展方法,这个方法用来解析这个算法,返回正确的列明,代码如下:
public
static
class TextBoxEx
{
public
static
string GetMapColumnsName(
this TextBox my)
{
string myColumnsName = my.ID;
//
将来文本ID可以为了安全存为加密过的值 这里可以负责解密
return myColumnsName;
}
}
这样就可以用很少的代码来解决,新增或者编辑时,页面的字段太多的问题啦!
2.应对需求的更变
现在我们如果页面的字段新增了,或者减少了,我们可以不必就该,提交按钮的事件,而是在页面上新增或者删除对应的展示控件就行啦!
例如页面有5个TextBox控件,如果需要加入一个我们只需在页面上多写一个TextBox控件,将ID写成自己加过密的文本,就OK了!