jquery easyui datagrid实现单行的上移下移,以及保存移动的结果

1、实现行的上移、下移、

说明:

1.1 通过datagrid生成的表格有固定的格式,比如,表格div的class名是datagrid-view。比如每一行tr都有id和datagrid-row-index属性等。

1.2 在上移和下移以后,我们将移动以后的两行的id和datagrid-row-index属性也必须互换,这样能保证datagrid-row-index=0的行肯定是

页面显示的表格的第一行,=1的是第二行等等。将来保存的时候,就是通过取这个属性值找某一行的数据的。

 1 function move(isUp) {
 2                 var selections = $dg.datagrid(‘getSelections‘);
 3                 if(selections.length == 0){
 4                     return;
 5                 }
 6                 var $view = $(‘div.datagrid-view‘);
 7                 var index = $dg.datagrid(‘getRowIndex‘,selections[0]);
 8                 var $row = $view.find(‘tr[datagrid-row-index=‘ + index + ‘]‘);
 9                 if (isUp) {
10                     $row.each(function(){
11                        var prev = $(this).prev();
12                        var prevId = prev.attr(‘id‘);
13                        var prevDatagridRowIndex = prev.attr(‘datagrid-row-index‘);
14                        var thisId = $(this).attr(‘id‘);
15                        var thisDatagridRowIndex = $(this).attr(‘datagrid-row-index‘);
16                        prev.length && $(this).insertBefore(prev);
17                        $(this).attr(‘id‘,prevId);
18                        $(this).attr(‘datagrid-row-index‘,prevDatagridRowIndex);
19                        prev.attr(‘id‘,thisId);
20                        prev.attr(‘datagrid-row-index‘,thisDatagridRowIndex);
21                     });
22                 } else {
23                     $row.each(function(){
24                        var next = $(this).next();
25                        var nextId = next.attr(‘id‘);
26                        var nextDatagridRowIndex = next.attr(‘datagrid-row-index‘);
27                        var thisId = $(this).attr(‘id‘);
28                        var thisDatagridRowIndex = $(this).attr(‘datagrid-row-index‘);
29                        next.length && $(this).insertAfter(next);
30                        $(this).attr(‘id‘,nextId);
31                        $(this).attr(‘datagrid-row-index‘,nextDatagridRowIndex);
32                        next.attr(‘id‘,thisId);
33                        next.attr(‘datagrid-row-index‘,thisDatagridRowIndex);
34                     });
35                 }
36             }

2、保存移动的结果

说明:每一个tr包含若干个td,每个td都有field属性,即表格展示对象的相应属性名,例子中goodsId是我要展示的商品的主键。每个td下都包含一个div,通过层层

find找到这个div以后,值就得到了。

 1 function nextStep() {
 2                 var arrayData = $dg.datagrid(‘getData‘).rows;
 3                 var $view = $(‘div.datagrid-view‘);
 4                 if(arrayData.length!=0){
 5                     saveIds = ‘‘;
 6                     for(var index=0;index<arrayData.length;index++){
 7                         var goodsId = $view.find(‘tr[datagrid-row-index=‘ + index + ‘]‘).find("td[field=‘goodsId‘]").find(‘div‘).html();
 8                         saveIds += goodsId;
 9                         if(index != arrayData.length-1){
10                             saveIds += ‘,‘;
11                         }
12                     }
13                     $.ajax({
14                        url:‘${pageContext.request.contextPath}/coupons/getTemplateId‘,
15                        type:‘post‘,
16                        dataType:‘json‘,
17                        success:function(result){
18                            window.location.href="${pageContext.request.contextPath}/coupons/tpl"+result+"?goodsId="+saveIds;
19                        }
20                      });
21                 }
22             }
时间: 2024-12-24 05:17:27

jquery easyui datagrid实现单行的上移下移,以及保存移动的结果的相关文章

jquery easyui datagrid 排序列

点击排序列,将获取参数有:page=1&rows=10&sort=UserName&order=desc c#后台获取sort跟order参数 string sortColumn = Request.Params["sort"].ToString(); string order = Request.Params["order"].ToString(); jquery easyui datagrid 排序列,布布扣,bubuko.com

Jquery easyui datagrid 导出Excel

datagrid的扩展方法,用于将当前的数据生成excel需要的内容. 1 <script> 2 /** 3 Jquery easyui datagrid js导出excel 4 修改自extgrid导出excel 5 * allows for downloading of grid data (store) directly into excel 6 * Method: extracts data of gridPanel store, uses columnModel to constru

jquery easyui datagrid设置行样式 不可删除某行

rowStyler: function (index,row) { if (parseInt(row.ksrs) > 0) { return 'color:red'; } }, onLoadSuccess:function(data){ var rows = data.rows; for (var j = 0; j < rows.length; j++) { if (parseInt(rows[j]["ksrs"]) > 0) { $(".datagrid-

JQuery easyUi datagrid 中 editor 动态设置最大值最小值

前言 近来项目中使用到 easyui 来进行页面设计,感觉挺方便的,但是网上除了api外,其他有价值的资料比较少,故在此分享一点经验,供大家参考. 问题 JQuery easyUi datagrid 可编辑行的editor属性具有 min 和 max 属性,设置可以输入的最大值和最小值,但是这个是固定的,如下: [html] view plain copy {field:'workRate',title:'<%/*填报*/%><bean:message key="task.wo

jQuery EasyUI datagrid实现本地分页的方法

本文实例讲述了jQuery EasyUI datagrid实现本地分页的方法.分享给大家供大家参考.具体如下: 一般分页都是后台做,前端做无论从哪方面考虑都不合适.但是有的时候还是有这种需求. 这里重点用到了pagination的监听,以及JS数组的slice方法来完成.代码如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 3

jQuery EasyUI Datagrid性能优化专题

jQuery EasyUI的Datagrid组件功能算是很强大了,不过性能确实不怎么乐观,而对于性能问题,网络上几乎也找不到相关的优化资料,所谓的牛人们可能 都望而却步了.本博客以后会带着分析Datagrid组件的性能问题,并且给出优化方案,也希望大家能集思广益,给出一些好的想法. 慢在哪些方面 以目前对Datagrid的了解程度去看待性能问题,主要有以下几点: 加载大数据量时比较慢(不考虑服务端返回数据的时间),这点尤其体现在IE浏览器里面: 大数据量时,加载后,操作很不流畅,勾选慢,sing

jQuery EasyUI DataGrid API 中文文档

扩展自$.fn.panel.defaults,用 $.fn.datagrid.defaults重写了 defaults . 依赖 panel resizable linkbutton pagination 用法 1.  <table id="tt"></table> 1.  $('#tt').datagrid({ 2.      url:'datagrid_data.json', 3.      columns:[[ 4.          {field:'co

jQuery EasyUI datagrid列名包含特殊字符会导致表格错位

首先申明:本文所述的Bug存在于1.3.3以及更高版本中,其它低版本,本人未测试,太老的版本不想去折腾了. 洒家在写前端的SQL执行工具时,表格用了 jQuery EasyUI datagrid,因为用户的SQL是千奇百怪的,所以出现了诸如:"BLOCKS*8/1024","trunc(SYSDATE)"之类的列名(field)时,表格就会错位,而且含有特殊字符的列无法手工调整大小. 经分析,datagrid组件在画表格的时候会在宿主DOM后动态追加一个style节

jquery easyUI datagrid 通过一般处理程序绑定数据库

初学easyui,搞了三天,终于将datagrid与后台数据库绑定成功,界面有点不太美观,以后继续努力. 后台一般处理程序取数据代码 1 <%@ WebHandler Language="C#" Class="jsonSms_group" %> 2 3 using System; 4 using System.Web; 5 using System.Configuration; 6 using System.Data; 7 using System.Da