ASP.NET Web 新增 编辑时 多字段取值 解决方案
2012-04-10 15:18
169 查看
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了!
相关文章推荐
- C#实现多级子目录Zip压缩解压实例 NET4.6下的UTC时间转换 [译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了 asp.Net Core免费开源分布式异常日志收集框架Exceptionless安装配置以及简单使用图文教程 asp.net core异步进行新增操作并且需要判断某些字段是否重复的三种解决方案 .NET Core开发日志
- ASP.NET 新增时多字段取值解决方案
- ASP.NET 新增时多字段取值解决方案
- 如何解决ASP.NET新增时多字段取值的问题
- 如何解决ASP.NET新增时多字段取值的问题
- ASP.NET Web用户控件中 路径的解决方案
- Microsoft Expression Web--对ASP.NET来说神器一般的网页编辑工具
- Asp.net中使用FCKEditor WEB编辑控件
- .net解决方案内有多个web项目时,启动调试如何只启动一个ASP.NET Development Server?
- asp.net IIS “/”应用程序中的服务器错误 解决方案[sql server 2000和 sql server 2005共存, web.config]
- Asp.net如何在Web页面上直接打开、编辑、创建Office文档
- Essential Studio for ASP.NET Web Forms发布2017 v2,新增自定义树形网格工具栏等
- asp.net GridView自定义模板列不可编辑列取值问题
- 编辑web.config,保证ASP.NET的安全
- ASP.NET WEB页面多语言支持解决方案
- ASP.NET 2.0中的数据操作:给新增、编辑界面增加验证控件 (翻译)
- ASP.NET WEB页面多语言支持解决方案
- Essential Studio for ASP.NET Web Forms发布2017 v2,新增自定义树形网格工具栏等
- ASP.NET(C#)中将TextBox控件的Readonly属性设置为True时后台直接取值取不到的解决方案
- 关于C#和ASP.NET中对App.config和Web.config文件里的[appSettings]和[connectionStrings]节点进行新增、修改、删除和读取相关的操作