ASP.net中的AJAX学习记录六 无刷新的数据编辑(GridView和DetailsView结合实例)

简介:
本篇博客是仿照书中实例,实现 GridView和DetailsView结合无刷新的数据编辑效果,页面效果:当点击GridView1的行或换页时,都会引发 DetailsView1的数据绑定显示至页面,同时当使用DetailsView1编辑、删除、添加时,也会引起GridView1的重新绑定,整体页面实现无刷新。
         页面布局:
        1.新建AJAX窗口,命名为:“ NoRefreshEdit.aspx”。要想实现页面无刷新编辑,就必须使用两个Updatepanel。
        2.在 NoRefreshEdit.aspx页面中加入一个一行二列的表,分别在每个单元格中放入一个Updatepanel。
        3.在Updatepanel1中加入一个表,最好加入一个数据数较多的表,方便你体会换页的刷新效果,我使用的是 tb_info表,按照我习惯的做法,直接将它拖入到Updatepanel1中,自动生成绑定好的GridView1和sqldatasource1.开启GridView1中的选择、分页功能。
        4.在Updatepanel2中放置一个sqldatasource2,将sqldatasource2的连接字符串也绑定到 tb_info表上,开始配置sqldatasource2。单击“高级”按钮,选中生成Insert、Update、Delete语句,单击“where”按钮,将ID绑定为GridView1的 SelectedValue事件触发的id值。
        5.拖放一个DetailsView1放入Updatepanel2中,将DetailsView1的数据源配置为sqldatasource2,启动编辑、删除、插入功能。
        6.将Updatepanel1的UpdateMode属性改为:conditional;将Updatepanel2的UpdateMode属性也改为conditional,同时在Updatepanel2的Triggers中加入两个Async-Postback,ControlID都是GridView1,Eventname分别是 SelectedIndexChangedPageIndexChanged,也就是说,当GridView1选择行和页码改变后,都会发生Updatepanel2的刷新,同时DetailsView1也会显示出来。
         页面布局到此,下面看一下cs代码:
1public partial  class NoRefreshEdit : System.Web.UI.Page 
2{ 
void Page_Load() void Page_Load(object sender, EventArgs e) 
4        { 

6        } 
void DetailsView1_ItemDeleted() void DetailsView1_ItemDeleted(object sender, DetailsViewDeletedEventArgs e) 
8        { 
9                GridView1.DataBind(); 
10                UpdatePanel1.Update(); 
11        } 
void DetailsView1_ItemInserted() void DetailsView1_ItemInserted(object sender, DetailsViewInsertedEventArgs e) 
13        { 
14                GridView1.DataBind(); 
15                UpdatePanel1.Update(); 
16        } 
void DetailsView1_ItemUpdated() void DetailsView1_ItemUpdated(object sender, DetailsViewUpdatedEventArgs e) 
18        { 
19                GridView1.DataBind(); 
20                UpdatePanel1.Update(); 
21        } 
22}
     那什么要编写这两行的代码,原因有二:1.DetailsView1并非是Updatepanel1的Triggers,所以它的任何动作不会刷新Updatepanel1控件,2.即使DetailsView1成为了Updatepanel1的Triggers,它的动作可以导致Updatepanel1的刷新,Updatepanel1刷新时也会因为GridView1控件没有重新绑定sqldatasource1,而持续显示上一次的列表。所以我们要同时让Updatepanel1刷新,也要让GridView1重新绑定。
     当Updatepanel的UpdateMode改为conditional时,除了可以使用Triggers中设定来要求何时刷新外,还可以直接于程序代码中调用其update函数来要求该Updatepanel刷新。
本文转自叶子文文博客51CTO博客,原文链接http://blog.51cto.com/leafwf/185629如需转载请自行联系原作者

叶子文文
相关文章
|
29天前
mvc.net分页查询案例——DLL数据访问层(HouseDLL.cs)
mvc.net分页查询案例——DLL数据访问层(HouseDLL.cs)
8 0
|
28天前
|
SQL 数据库
使用ADO.NET查询和操作数据
使用ADO.NET查询和操作数据
9 0
|
2月前
|
SQL 开发框架 .NET
ASP.NET WEB+EntityFramework数据持久化——考核练习库——1、用户管理系统(考点:查询列表、增加、删除)
ASP.NET WEB+EntityFramework数据持久化——考核练习库——1、用户管理系统(考点:查询列表、增加、删除)
67 0
|
4月前
|
Oracle 关系型数据库 数据管理
.NET医院检验系统LIS源码,使用了oracle数据库,保证数据的隔离和安全性
LIS系统实现了实验室人力资源管理、标本管理、日常事务管理、网络管理、检验数据管理(采集、传输、处理、输出、发布)、报表管理过程的自动化,使实验室的操作人员和管理者从繁杂的手工劳作中解放出来,提高了检验人员的工作效率和效益,降低了劳动成本和差错发生率。
|
5月前
|
开发框架 前端开发 .NET
用ajax和asp.net实现智能搜索功能
用ajax和asp.net实现智能搜索功能
43 0
|
6月前
|
前端开发 JavaScript
.net core 前端传递参数有值 后端接收到的数据却是null
1、问题分析 在做接口测试时,偶然出现了前端输出有值,但是后端断点调试时却出现接收参数总是为null的情况 2、解决办法 前端打印log,看前端的每一个传值的数据类型,与后端请求参数类进行认真的一一比对 小技巧: ① 直接打印调用接口的传参值的数据类型,例如 console.log(type of this.form.name) --string console.log(type of this.form.age) --number 打印的数据类型与后端接口的参数类比对,查出不对应的类型 ② 关于非必填的值,默认传值可能出现空字符串(' ')、NaN值(Not a Number
97 0
|
6月前
|
SQL 开发框架 监控
|
7月前
|
JSON 数据格式
.NET Core - 配置绑定:使用强类型对象承载配置数据
.NET Core - 配置绑定:使用强类型对象承载配置数据
|
5月前
|
XML 前端开发 JavaScript
什么是Ajax和jquery
什么是Ajax和jquery
38 0