Wijmo 更优美的jQuery UI部件集:客户端更改C1GridView数据源

简介:

很多时候,我们在使用 GridView 展示数据时,希望最终用户可以编辑数据并且同步到数据源中。这是一项繁琐的工作。我们需要自定义模板列,并且在后台手动获取更新值,最后使用 SQL 语句同步到数据库中。

 但是,现在我们有了 C1 Wijmo GridView ,这些繁琐的工作都成为历史。C1GridView 仅仅通过一个属性-AllowClientEditing 便允用户在客户端编辑单元格内容。

需要编辑时,我们可以通过双击单元格使其进入编辑状态即可。完成编辑后,选择其它单元格去保存编辑值。

 这篇文章将叙述在不执行任何 PostBack 的情况下,如何轻而易举的更新数据库。

 

1.定义数据库连接字符串并且绑定到 C1GridView

C1GridView 可以绑定 Oledb 数据源或 SQL 数据源。本文中,我们将使用 Oledb 数据源。请根据下面的代码设置 DataKeyNames 和 C1GridView 相关列。同时,我们需要设定 CallbackSettings 值为 editing ,这样在我们保存时,不会发生 Postback。

参考代码:

 


 
 
  1. <wijmo:C1GridView ID="C1GridView1" runat="server" 
  2.  
  3. AutogenerateColumns="false" DataKeyNames="CustomerID" ClientSelectionMode="SingleRow" 
  4.  
  5. AllowClientEditing="true" ShowFilter="true" 
  6.  
  7. OnEndRowUpdated="C1GridView1_EndRowUpdated"> 
  8.  
  9. <CallbackSettings Action="Editing, Filtering" /> 
  10.  
  11. <Columns> 
  12.  
  13. <wijmo:C1BoundField DataField="CustomerID" HeaderText="CustomerID" SortExpression="CustomerID"> 
  14.  
  15. </wijmo:C1BoundField> 
  16.  
  17. <wijmo:C1BoundField DataField="CompanyName" HeaderText="Company Name" SortExpression="CompanyName"> 
  18.  
  19. </wijmo:C1BoundField> 
  20.  
  21. <wijmo:C1BoundField DataField="ContactName" HeaderText="Contact Name" SortExpression="ContactName"> 
  22.  
  23. </wijmo:C1BoundField> 
  24.  
  25. <wijmo:C1BoundField DataField="City" HeaderText="City" SortExpression="City"> 
  26.  
  27. </wijmo:C1BoundField> 
  28.  
  29. <wijmo:C1BoundField DataField="Country" HeaderText="Country" SortExpression="Country"> 
  30.  
  31. </wijmo:C1BoundField> 
  32.  
  33. </Columns> 
  34.  
  35. </wijmo:C1GridView> 

 

2.下面,我们定义 Oledb 数据库连接字符串。因为需要将更改同步到数据库中,所以我们需要写 SQL 语句去同步数据源。

参考代码:

 


 
 
  1. public DataTable GetDataTable() 
  2.  
  3.  
  4. DataTable dt = Page.Session["Customers"as DataTable; 
  5.  
  6. OleDbConnection con = new OleDbConnection("provider=Microsoft.Jet.Oledb.4.0; Data Source=" + Server.MapPath("~/App_Data/C1NWind.mdb")); 
  7.  
  8. OleDbDataAdapter da = new OleDbDataAdapter(); 
  9.  
  10. da.SelectCommand = new OleDbCommand("SELECT * FROM [Customers] Order By [CustomerID]", con); 
  11.  
  12. da.UpdateCommand = new OleDbCommand("Update [Customers] set [CompanyName]=?, [ContactName]=?, [City]=?, [Country]=? where CustomerID = ?", con); 
  13.  
  14. da.UpdateCommand.Parameters.Add("@CompanyName", OleDbType.VarChar, 50, "CompanyName"); 
  15.  
  16. da.UpdateCommand.Parameters.Add("@ContactName", OleDbType.VarChar, 50, "ContactName"); 
  17.  
  18. da.UpdateCommand.Parameters.Add("@City", OleDbType.VarChar, 50, "City"); 
  19.  
  20. da.UpdateCommand.Parameters.Add("@Country", OleDbType.VarChar, 50, "Country"); 
  21.  
  22. da.UpdateCommand.Parameters.Add("@CustomerID", OleDbType.VarChar, 50, "CustomerID"); 
  23.  
  24. if (dt == null
  25.  
  26.  
  27. dt = new DataTable(); 
  28.  
  29. da.Fill(dt); 
  30.  
  31. dt.PrimaryKey = new DataColumn[] { dt.Columns["CustomerID"] }; 
  32.  
  33. Page.Session["Customers"] = dt; 
  34.  
  35.  
  36. da.Update(dt); 
  37.  
  38. return dt; 
  39.  

3.我们仅需在 RowUpdating 和 EndRowUpdated 事件中更新被编辑的行。在客户端使用 C1 Wijmo GridView 修改数据源。


 
 
  1. protected void C1GridView1_RowUpdating(object sender, C1.Web.Wijmo.Controls.C1GridView.C1GridViewUpdateEventArgs e) 
  2.  
  3.  
  4. DataTable customers = GetDataTable(); 
  5.  
  6. DataRow row = customers.Rows.Find(C1GridView1.DataKeys[e.RowIndex].Value); 
  7.  
  8. if (row != null
  9.  
  10.  
  11. foreach (DictionaryEntry entry in e.NewValues) 
  12.  
  13.  
  14. row[(string)entry.Key] = entry.Value; 
  15.  
  16.  
  17.  
  18. else 
  19.  
  20.  
  21. throw new RowNotInTableException(); 
  22.  
  23.  
  24. Page.Session["Customers"] = customers; 
  25.  

在 EndRowUpdated 事件中重新绑定 C1GridView 数据源。

 


 
 
  1. protected void C1GridView1_EndRowUpdated(object sender, C1.Web.Wijmo.Controls.C1GridView.C1GridViewEndRowUpdatedEventArgs e) 
  2.  
  3.  
  4. C1GridView1.DataSource = GetDataTable(); 
  5.  
  6. C1GridView1.DataBind(); 
  7.  

1

 

不过,有时 C1GridView 中仅仅有一行数据(例如:执行了过滤操作)。用户编辑这一行,但是我们并没有其他行可以点击,从而无法保存更改。不要着急!

我们只需要添加 button 去调用 C1GridView 的前台方法 Update即可。


 
 
  1. <asp:Button ID="btn1" runat="server" Text="Update C1GridView"OnClientClick="btn_ClientClick(); return false;" /> 

 

使用下面代码调用 Update() 方法:

 


 
 
  1. function btn_ClientClick(sender, args) 
  2.  
  3.  
  4. var grid = $("#C1GridView1"); 
  5.  
  6. grid.c1gridview("endEdit"); 
  7.  
  8. grid.c1gridview("update"); 
  9.  

 

好了,现在我们可以运行程序查看效果了。

2



本文转自 powertoolsteam 51CTO博客,原文链接:http://blog.51cto.com/powertoolsteam/860612,如需转载请自行联系原作者

相关文章
|
JSON 前端开发 JavaScript
【前端】使用jQuery封装一套UI组件 - 级联选择器组件
本篇文章来讲解下级联选择器组件 级联选择器,在实际项目中也是比较常用的组件,比如:省市区三级关联,上下级联动等 最后面会附上全部代码
1326 0
|
5月前
|
Web App开发 缓存 JavaScript
JQuery Kendo UI使用技巧总结
JQuery Kendo UI使用技巧总结
38 4
jquery-easyui和jquery-ui的slider冲突解决
jquery-easyui和jquery-ui的slider冲突解决
|
JavaScript 前端开发 程序员
【前端】使用jQuery封装一套UI组件 - 是和否滑动切换组件
本篇文章来讲解下是和否的滑动切换组件 切换滑动组件,使用的场景实际上就是一个开和关的场景,一般有是和否,开和关,禁用和启用等等,只需要设置0和1即可
146 0
|
JavaScript 前端开发 程序员
【前端】使用jQuery封装一套UI组件 - 可编辑下拉框组件
下拉框也是比较常用的组件,对应原生的下拉标签就是select 本篇文章就来讲讲可编辑下拉框组件的封装过程
362 0
|
JavaScript 前端开发 程序员
【前端】使用jQuery封装一套UI组件 - 移动端时间选择组件
【首先要声明一点,技术不分好坏,能用好就行,不用鄙视老技术】 今天要给大家展示的是移动端时间选择组件 最开始,看到比较新颖的移动端时间选择组件是在某款手机上,分年月日下拉选择,UI界面也挺好看的 除了讲解实现的步骤以及关键点,文章最后面会有完整的代码
241 0
|
前端开发 JavaScript 程序员
【前端】使用jQuery封装一套UI组件 - 单选框
目前前端技术发展非常快,各大厂都开源和分享了自家的前端框架,非常多成熟的UI组件供大家选择,很实用也很方便,给开发上节省了不少时间成本,当然少不了学习成本,不过也不会占用太多时间,只要有前端基础的话,原理基本都是通用的,只是写法不一样。 因此,除了学习现有的优秀前端之外,最好能自己根据原理封装一套自己的UI组件,目的是为了更好的理解前端知识点以及锻炼编程逻辑
164 0
|
JavaScript
jQuery UI 自定义样式的日历控件
在线演示 本地下载
1282 0