您现在的位置是:网站首页> 编程资料编程资料
如何解决ASP.NET新增时多字段取值的问题_实用技巧_
2023-05-24
471人已围观
简介 如何解决ASP.NET新增时多字段取值的问题_实用技巧_
ASP.NET 开发人员在卡发时经常会碰到一个情况,就是新增的页面中字段太多,在点击保存的时候需要一个一个的赋值实体或者构建SQL语句去保存。这样不仅浪费体力还需要占用大量的文本行控件去写代码。经过构思是否可以使用一种更方便的办法去解决呢?提高代码的内聚性。
1.思路
我们知道一般新增页面最多的就是一大堆文本框让用户输入内容,然后点击保存按钮进行提交将数据持久化到数据库。
在点击提交的时候传统方式就是一个一个文本框的读取赋值。
HTML代码如下:
按钮提交事件代码:
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 entityDic = new Dictionary(); 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新增时多字段取值问题的方法,希望大家仔细阅读,运用到自己的学习当中。
相关内容
- ASP.NET显示渐变图片实现方法_实用技巧_
- ASP.NET文件处理如何操作_实用技巧_
- ASP.NET Forms身份认证详解_实用技巧_
- 灵活掌握asp.net中gridview控件的多种使用方法(上)_实用技巧_
- APS.NET MVC4生成二维码简单解析_实用技巧_
- 解决asp.net mvc UpdateModel更新对象后出现null问题的方法_实用技巧_
- 总结十条.NET异常处理建议_实用技巧_
- 浅析.NET逻辑分层架构_实用技巧_
- Microsoft Visual Studio 2010下如何添加命令提示行_实用技巧_
- 分享Visual Studio原生开发的10个调试技巧(2)_实用技巧_
