欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【DataGrid的多行提交】,下面是详细的分享!
DataGrid的多行提交
尽管ASP.NET DataGrid是众所周知非常好的表格控件,不过,提起DataGrid的编辑功能,我们却不敢恭维了,就拿DataGrid的数据提交功能来说,的确存在很大的问题:在DataGrid中,每编辑一行就要提交一行,即所谓“单行编辑、单行提交”,这样的话,如果编辑的行数过多,不仅用户操作繁琐,还会造成对服务器的频繁访问,极大降低系统效率。
当然了,有一种借尸还魂的解决方法,那就是把所要编辑的内容转到其他的页中在TextBox中进行编辑。不过,仔细想想,这种方法难道不是自己在骗自己吗,还有在Grid中我们编辑的时候总不能老是用Tab键来实现Grid(TextBox)之间的跳转吧,如果响应回车事件,那么需要程序员浪费很大的精力来开发。
如何解决上述问题呢?下面我向大家推荐一个我正在使用的国产DataGrid:SmartGrid(天空软件站可以下载:http://www.skycn.com/soft/23547.html ),这个控件我已经用了好长的时间了,现在来同大家探讨一下SmartGrid的多行提交的方法:SmartGrid并没有DataGrid中的那些按钮列而是整个的表单只有一个提交按钮,无论你更改了一行或者是多行都可以一次性的提交,下面来随便看点例子:
实例:
上图中是一个比较好的编辑的例子,例子显示,你可以编辑多行也可以编辑一行,然后一起进行提交。
代码:
修改按钮的代码:
private void btonSave_Click(object sender, System.EventArgs e)
{
this.DataGrid1.ReadOnly=false;//进入编辑
this.DataGrid1.AllowAdd=true;//允许添加
this.DataGrid1.AllowDelete=true;//允许删除
}
此段代码是smartgrid的独有的属性你可以设添加删除 编辑 的各种的功能
保存按钮的代码:
private void Button2_Click(object sender, System.EventArgs e)
{
DataTable t=(DataTable)this.SmartGrid1.DataSource;
this.sqlDataAdapter1.Update(t);
t.Clear();
this.sqlDataAdapter1.Fill(t);
this.SmartGrid1.DataSource=t;
}
还有一种是数据逐行的提交到服务器
代码:
private void btonSave_Click(object sender, System.EventArgs e)
{
DataTable tb=(DataTable)this.SmartGrid1.DataSource;
SqlParameter[] parameters=new SqlParameter[5];
foreach(DataRow dr in tb.Rows)
{
parameters[0]=new SqlParameter("@customerId",""+dr[1]+"");
parameters[1]=new SqlParameter("@companyName",""+dr[0]+"");
parameters[2]=new SqlParameter("@contactName",""+dr[2]+"");
parameters[3]=new SqlParameter("@contactTitle",""+dr[3]+"");
parameters[4]=new SqlParameter("@address",""+dr[4]+"");
//EamPd 是类Execute是执行存储过程的函数parameters是存储过程所需要的参数
EamPd.Execute("CreatLayer",parameters);
}
}
以上所分享的是关于DataGrid的多行提交,下面是编辑为你推荐的有价值的用户互动:
相关问题:jquery easyui datagrid 一行数据怎么多行显示??
答:你可以试下在后台做数据处理,加个返回前台,看行不行。 >>详细
相关问题:各位大虾: 在VB中怎样实现DataGrid中数据的批量录...
答:可以啊,你直接用循环语句调用数据库里的数据来实现录入啊,包括删除及新增都可以实现,我以前用VB做过程序的,就经常使用DataGrid控件。 >>详细
相关问题:EasyUI datagrid 如何默认选择多行
答:EasyUI datagrid 选择多行的方法: SingleSelect:false,即可实现选择多行。 【解析】 原因分析: datagrid 中的 idField 属性,必须对应后台的实体属性字段,而且该字段必须确保唯一性,一般用id标识,否则就无法获取在datagrid中选择的多条记录... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
