转自:http://blog.csdn.net/abauch_d/article/details/7734395

前几天我把easyui dadtagrid的增删改查的实现代码贴了出来,发现访问量达到100多,那次由于匆忙,只把代码贴出来而已,看到有这么多的朋友想学这个框架,今天我就试着跟大家一起来探讨一下这个datagrid吧

1、首先是datagrid的数据展示:

我的做法是在页面中定义了表格的字段名称,代码如下:(当然这里还有别的方法,大多数的做法是在页面中放一个table节点,然后在js文件中定义表格的字段等等属性)

<table id="tt">
     <thead>
    <tr>
    <th field="id" width="80" >读者ID</th>
    <th field="name" width="100" >读者姓名</th>
    <th field="sex" width="80" >性别</th>
    <th field="type" width="80" >类型</th>
    <th field="email" width="80" >邮箱</th>
    <th field="company" width="150">单位</th>
    <th field="status" width="60">状态</th>
    </tr>
    </thead>
    </table>

写脚本文件:

$(function() {

//设置datagrid
  var lastIndex;
  
 $('#tt').datagrid({
   width : 750,
   height : 350,
   //pageSize:5,
   pageList : [ 5, 10, 15, 20 ],
   pageSize:10,
   nowrap : false,
   striped : true,
   collapsible : true,
   url : '../datagrid/test.action',
   loadMsg : '数据装载中......',
   sortName : 'code',
   sortOrder : 'desc',
   idField : 'id',
   remoteSort : false,
   pagination : true,
   rownumbers : true,
   frozenColumns : [ [ {
    field : 'ck',
    checkbox : true
   } ] ],            
   toolbar : [ {
    text : '添加',
    iconCls : 'icon-add',
    handler : function(){
      $('#add').window('open');
         $('#fs').show();
         $('#fs').form('clear');
         $('#fs').appendTo('#aa');
    }
   }, '-', {
    text : '删除',
    iconCls : 'icon-remove',
    handler : del
   }, '-', {
    text : '保存',
    iconCls : 'icon-save',
    handler : function() {
     $('#tt').datagrid('acceptChanges');
    }
   }, '-', {
    text : '修改',
    iconCls : 'icon-edit',
    handler : getSelect
   }, '-', {
    text : '查询',
    iconCls : 'icon-search',
    handler : function() {
     $('#query').window('open');
    }
   }, '-', {
    text : '撤销',
    iconCls : 'icon-undo',
    handler : function() {
     $('#tt').datagrid('rejectChanges');
    }
   } ],
   onBeforeLoad : function() {
    $(this).datagrid('rejectChanges');
   }
  });

红色部分中,最重要的是url,大家看这个名称也知道,这是从后台获取到数据的地址,之前自己刚开始在学这个框架的时候在网上找了很多例子

很多网友只是说了这是个获取数据的地址,但是后台到底怎么返回数据给前端,大家都没怎么提到,在这里我就将我的方法跟大家分享一下,我是基于ssh框架开发的,所

以这个地址其实就是指向到struts2的一个action处理程序,在该action中我获取数据库的数据,至于怎么获取数据,相信大家应该都会了,这里我们重点讲一下后台是返回

什么样的数据给前端,然后显示在datagrid中:其实后台返回的数据是一个json格式的字符串,格式大致是这样的

{"total":28,"rows":[
 {"id":"FI-SW-01","sex":"fale"},
 {"id":"K9-DL-01","sex":"male"}
 ]}

返回的json字符串很像是键值对,每个键的名称都必须与之前table定义的字段名一致,这是在datagrid展示数据的保证,所以大家想要返回什么样的数据都可以通过自己构造

json字符串来返回给前端。

至于toolbar,就是一个工具栏,里面定义了许多按钮,添加,删除,修改等等,handler这是当点击该按钮时触发的事件。

2、然后是增删改查的操作

其实大家只要明白对数据进行增删改查操作只要能够将想要操作的那一条或一组数据获取到,然后传值到后台,再交由后台执行对数据库的操作就行了,

所以在这里关键是如何获取到datagrid的数据

添加操作的话,我的上一篇文章有把代码贴出来了,其实就是当点击添加按钮,就弹出一个子窗口,然后填入信息后提交到后台action处理,由于用的是strust2,所以连参数

都不用直接传递了,直接让action以它里面定义的变量去页面寻找对应的值并赋值就可以了,这个比较简单,我就不多说了

然后是修改操作,具体的代码由于之前都贴出来了,现在就不再复制在这里了。修改前要做的就是获取到你要修改的数据,这可以由$('#tt').datagrid('getSelected')这条语句来

实现,它是获取datagrid中被选中行的记录,然后只要把该行的数据展示出来,让用户去修改,然后再像添加一样提交到actioin中就可以了

删除操作,删除操作也比较简单,只需要取到选中的记录的ID号并提交到后台就行了

查询操作,获取到要查询的信息后,提交到后台,然后只要像显示数据那样构造返回到前端的json字符串就行了

以上这些希望能够帮到大家,针对我的做法有什么建议的或者有哪些不对的也请赐教。

详谈easyui datagrid增删改查操作的更多相关文章

  1. Node.js、express、mongodb 入门(基于easyui datagrid增删改查)

    前言 从在本机(win8.1)环境安装相关环境到做完这个demo大概不到两周时间,刚开始只是在本机安装环境并没有敲个Demo,从周末开始断断续续的想写一个,按照惯性思维就写一个增删改查吧,一方面是体验 ...

  2. easyui datagrid 增删改查示例

    查询JSP页面 <!doctype html> <%@include file="/internet/common.jsp"%> <!-- 新样式右侧 ...

  3. asp.net mvc4 easyui datagrid 增删改查分页 导出 先上传后导入 NPOI批量导入 导出EXCEL

    效果图 数据库代码 create database CardManage use CardManage create table CardManage ( ID ,) primary key, use ...

  4. golang学习之beego框架配合easyui实现增删改查及图片上传

    golang学习之beego框架配合easyui实现增删改查及图片上传 demo目录: upload文件夹主要放置上传的头像文件,main是主文件,所有效果如下: 主页面: 具体代码: <!DO ...

  5. MVC与EasyUI结合增删改查

    构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(9)-MVC与EasyUI结合增删改查   在第八讲中,我们已经做到了怎么样分页.这一讲主要讲增删改查.第六讲的 ...

  6. abp(net core)+easyui+efcore实现仓储管理系统——ABP WebAPI与EasyUI结合增删改查之一(二十七)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  7. mongoVUE的增删改查操作使用说明

    mongoVUE的增删改查操作使用说明 一. 查询 1. 精确查询 1)右键点击集合名,再左键点击Find 或者直接点击工具栏上的Find 2)查询界面,包括四个区域 {Find}区,查询条件格式{& ...

  8. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  9. PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码

    PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty) dbconn.php <?php //------------------------使用PDO方式连接数据库文件- ...

随机推荐

  1. OC加强-day03

    #program mark - 0_18 分类的使用注意 [掌握] 1.分类的作用 作用:讲一个类分为多个模块,将相似功能的方法写在同一个模块中,方便我们后面代码的维护 "强调 1.分类中只 ...

  2. 获取通讯录的信息(关于iOS9.0之后新的框架-ContactFramework)

    转载自:http://my.oschina.net/u/2340880/blog/511995?p={{totalPage}} 一.引言 在以前iOS开发中,涉及联系人相关的编程,代码都非常繁琐,并且 ...

  3. 控制器的跳转-modal与push

    一.modal与pushmodal从下面往上盖住原来的控制器,一般上一个控制器和下一个控制器没有什么关联时用modal,比如联系人的加号跳转页面,任何控制器都可以用modal push一般是上下文有关 ...

  4. c#接口深入一步探究其作用,适合新人了解

    前言 前一篇浅显的述说了一下c#接口的作用,并用了一个不怎么好的例子述说了一下.时隔一天,在看完大家的评论后我在论坛中查看了很多前辈们对c#接口的描述,发现大家对例子的说明不是太容易让我们这些新人理解 ...

  5. ReactNative-----环境搭建(android)

    1.参考文档 http://reactnative.cn/docs/0.26/getting-started.html http://reactnative.cn/docs/0.26/running- ...

  6. struts1、 struts2所有版本jar包下载地址大全

     jakarta-struts-1.2.2.tar.gz      30-Aug-2004 18:21   12M  jakarta-struts-1.2.2.tar.gz.asc  30-Aug-2 ...

  7. Peter Pan By: J. M. Barrie

    Audio book: (mp3+txt) http://www.booksshouldbefree.com/book/peter-pan-by-j-m-barrie

  8. Stay Hungry, Stay Foolish--2005斯坦福大学05年毕业演讲

    转自http://www.cnblogs.com/daizhj/articles/1493813.html 斯蒂夫•保罗•乔布斯(Steve Paul Jobs,1955年2月24日出生-)是蘋果電腦 ...

  9. scala - 从合并两个Map说开去 - foldLeft 和 foldRight 还有模式匹配

    开发中遇到需求:合并两个Map集合对象(将两个对应KEY的值累加) 先说解决方案: ( map1 )) ) } 这特么什么鬼  (╯‵□′)╯""┻━┻☆))>○<)  ...

  10. 身份证js验证

    <script type="text/javascript"> //--身份证号码验证-支持新的带x身份证 function isIdCardNo(num) { var ...