ASP.NET 新增时多字段取值解决方案
2011-12-24 22:06
204 查看
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了!
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了!
相关文章推荐
- ASP.NET Web 新增 编辑时 多字段取值 解决方案
- ASP.NET 新增时多字段取值解决方案
- 如何解决ASP.NET新增时多字段取值的问题
- 如何解决ASP.NET新增时多字段取值的问题
- C#实现多级子目录Zip压缩解压实例 NET4.6下的UTC时间转换 [译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了 asp.Net Core免费开源分布式异常日志收集框架Exceptionless安装配置以及简单使用图文教程 asp.net core异步进行新增操作并且需要判断某些字段是否重复的三种解决方案 .NET Core开发日志
- 新增多个字段时取值解决方案
- ASP.NET(C#)中将TextBox控件的Readonly属性设置为True时后台直接取值取不到的解决方案
- ASP.Net TextBox只读时不能取值的解决方案
- asp.net: GridView相关技术(五--模板列绑定字段过长的解决方案)
- ASP.Net TextBox只读时不能取值的解决方案
- Asp.net字段太小而不能接受所要添加的数据的数量的解决方案
- asp.net 链接 oracle 解决方案
- JQuery FlexiGrid的asp.net完美解决方案-dotNetFlexGrid使用指南(一)
- [转] 关于ASP.NET中由于无法创建应用程序域,因此未能执行请求解决方案
- 关于AJAX跨域调用ASP.NET MVC或者WebAPI服务的问题及解决方案
- ASP.NET中实现Form表单字段值自动填充到操作模型中
- win7+iis7.5+asp.net下 CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET\Framework\v2.0.50727\Temporary ASP.NET Files 解决方案
- ASP.NET MVC下基于异常处理的完整解决方案
- Asp.Net MVC 如何给依赖字段添加验证
- ASP.Net中模板解决方案--显示模板列表及模板说明