JQuery EasyUI DataGrid 编程经验

转载 2015年07月07日 18:47:55

原创地址:http://xiaomao870311.blog.51cto.com/1458701/384400

最近,在项目中用到JQuery EasyUI DataGrid,虽然它封装了表格的实现,为我们提供很多便利,但是在使用的过程中,还是会遇到一些困难和问题。目前,问题都已经解决,特分享我使用DataGrid开发的经验。(PS:我用的是JSP和J2EE框架开发)。

1.数据的提取和显示。

DataGrid是通过url属性获取数据的。例如:url:'ListInfo.action',这样通过调用Action中的方法获取数据。返回的是JSON字串。注意,JSON字串必须按照DataGrid定义的数据格式进行拼装。这种数据格式,可以参考我前面的文章中的附件。特别强调的是,JSON字串中的total域的值是数据的条数,用于数据的分页。

2.数据的分页。

数据的分页分为前台分页和后台分页,前台分页,DataGrid已经封装好了。DataGrid定义了两个参数: rows(每页的条数),page(当前的页数),这两个参数分别对应属性pageSize,pageNumber。用户可以在pageSize,pageNumber属性中设置,也可以不设置,这样就取默认值。我们只需在Action中定义两个变量,private int rows; private int page; 接着通过SQL语句获取需要取的值。分页的SQL语句(Oracle)如下:

  1. select * from(   
  2. select rownum r,  field1,field2 from table_name where rownum <= page* rows( 
  3. )    
  4. where r > (page-1) * rows  

这样提取的数据的条数赋值给total域,拼装在JSON字串中返回,就可以实现分页了。当然,pagination:true,是当然需要的。

3.数据的操作。

数据的操作大致可分为:查看,删除。对于查看,我们可以通过onClickRow或onDblClickRow事件实现。如:

$(function(){
   $('#test').datagrid({
    title:'数据列表',
    width:900,
    height:500,

        .......(省略的属性)

    onDblClickRow: function() {
    var selected = $('#test').datagrid('getSelected');
    if (selected){
      window.open("DataView.action?Id="+selected.ID);
   }}
       这样双击就可以查看了。

关于删除,可以通过点击删除按钮,调用删除方法来实现。删除按钮可以在拼装JSON字串的时候,赋值给OPERATION域,这样设置{field:'OPERATION',title:'操作',width:120},就可以在页面上显示删除按钮了。删除的实现,如下:

function DelAff(){
   $.messager.confirm('确认','是否真的删除?',function(r){ 
   if (r){ 
   var selected = $('#test').datagrid('getSelected');
   if (selected){
      var index = $('#test').datagrid('getRowIndex', selected);
      $('#test').datagrid('deleteRow', index);
    DeleteSubmit(selected);
   }
   }
   });
  }
  function DeleteSubmit(selected)
  {
       var url="DataDelete.action?Id="+selected.ID;
       $.post(
       url     
     );
  }         这样页面的删除和数据库中的删除都实现了。

4.待解决的问题

如果返回的数据为空,则在IE浏览器下,页面会有Bug。我的解决办法是,把每个域设为"",这样在页面上就会出现一行空内容的数据。如果遇到这个问题并解决的朋友,可以给我建议。

JQuery EasyUI DataGrid 编程经验

最近,在项目中用到JQuery EasyUI DataGrid,虽然它封装了表格的实现,为我们提供很多便利,但是在使用的过程中,还是会遇到一些困难和问题。目前,问题都已经解决,特分享我使用DataGr...

【项目经验】--EasyUI DataGrid之右键菜单

前两天验收项目,老总提了一个不是需求的需求,为什么这么说呢?因为我们的管理不到位!话说当天,我们UI系统下发了一个总文件,上面写着“各个系统找一个没有添加UI的模块去添加最新版本UI进行测试”,然后过...

SpringData JPA easyUI dataGrid数据显示的解决经验

最近,初学SpringMVC,用的是springDataJPA。前台用的是EasyUI的datagrid显示数据。刚开始,搞了半天数据就是表示不出来,后台代码运行正常,前台js也没问题。蛋疼的一个下午...

jquery easyui datagrid性能优化

  • 2017年11月24日 19:25
  • 81KB
  • 下载

jquery_easyui_DataGrid分页操作

  • 2012年03月10日 21:51
  • 75KB
  • 下载

easyui datagrid 经验

datagrid    1、在复制行的时候,tb.datagrid('appendRow')的时候,不能直接拿要复制的row。而要把要复制的的列挨个写出来。       否则会出现复制行之后改动了...

JQuery_EasyUI_DataGrid_中文文档

  • 2012年07月11日 22:12
  • 21KB
  • 下载

jquery easyui datagrid demo

  • 2011年08月19日 23:00
  • 1007KB
  • 下载

【颗粒归仓】(一)jQuery easyui datagrid 的数据加载

其实easyuidatagrid加载数据只有两种方式:一种是ajax加载目标url返回的json数据;另一种是加载js对象,也就是使用loadDate方法,这种方法用于加载本地js数据(非url调用)...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JQuery EasyUI DataGrid 编程经验
举报原因:
原因补充:

(最多只允许输入30个字)