easyui datagrid 列拖拽2
1、拖动前
2、拖动中
3、拖动后
5、代码1
- $("#corp-grid").datagrid({
- title:"泥头车企业管理",
- toolbar:"#corp-grid-toolbar",
- border:false,
- fit:true,
- width:$(window).width()-252,
- columns:[[
- {field:"ckb",checkbox:true},
- {field:"corpName",title:"企业名称",width:200,halign:"center",align:"center",resizable:true},
- {field:"linkedCorpName",title:"挂靠深圳企业名称",width:200,halign:"center",align:"center",resizable:true},
- {field:"corpType",title:"企业类型",width:80,align:"center",resizable:false},
- {field:"businessScope",title:"经营范围",width:80,align:"center",resizable:false},
- {field:"effectiveDate",title:"有效日期",width:80,align:"center",resizable:false},
- {field:"opePeriod",title:"营业期限",width:80,align:"center",resizable:false},
- {field:"ifLocal",title:"是否本地",width:80,align:"center",resizable:false},
- {field:"state",title:"有效状态",width:80,align:"center",resizable:false}
- ]],
- //striped:true,
- fitColumns:true,
- //autoRowHeight:true,
- rownumbers:false,
- singleSelect:false,
- ctrlSelect:true,
- pagination:true,
- pageSize:10,
- pageList:[5,10,15,20,25,30],
- sortName:"corpId",
- sortOrder:"desc",
- url:"corp_getInfoList.action",
- method:"post",
- loadMsg:"加载数据中,请稍后",
- onDblClickRow:function(rowIndex, rowData){
- openDialog({
- type:"view",
- title:"泥头车企业信息查看",
- width:800,
- height:400,
- maximizable:true,
- href:"BaseInfo/Corp/CorpInfoView.html"
- });
- },
- onRowContextMenu:function(e, rowIndex, rowData){
- e.preventDefault();
- $(this).datagrid("unselectAll");
- $(this).datagrid("selectRow", rowIndex);
- $("#corp-menu").menu("show",{
- left:event.pageX,
- top:event.pageY
- });
- }
- }).datagrid("columnMoving");
6.代码2
- $.extend($.fn.datagrid.methods,{
- columnMoving:function(jq){
- return jq.each(function(){
- var grid = this;
- var directionDiv = $("<div></div>");
- directionDiv.hide();
- $("body").append(directionDiv);
- $(grid).datagrid("getPanel")
- .find(".datagrid-header td[field]:not(td[field='ckb'])").draggable({
- revert:true,
- cursor:"move",
- deltaX:10,
- deltaY:10,
- edge:10,
- proxy:function(source){
- var proxyEl = $("<div></div>");
- proxyEl.addClass("dg-proxy dg-proxy-error");
- proxyEl.text($(source).text());
- proxyEl.appendTo($("body"));
- return proxyEl;
- }
- }).droppable({
- accept:".datagrid-header td[field]",
- onDragOver:function(e,source){
- $(source).draggable("proxy").removeClass("dg-proxy-error").addClass("dg-proxy-right");
- $(".dg-hide-div").hide();
- var thisIndex = $(this).index();
- var sourceIndex = $(source).index();
- var className = null;
- var height = null;
- var thisOffset = null;
- var left = null;
- var top = null;
- height = $(this).height();
- if(sourceIndex > thisIndex){
- className = "dg-move-prev";
- thisOffset = $(this).offset();
- left = thisOffset.left;
- top = thisOffset.top;
- }else{
- className = "dg-move-next";
- if(thisIndex == $(this).parent().children(":last").index()){
- thisOffset = $(this).offset();
- left = thisOffset.left + $(this).width() - directionDiv.width();
- top = thisOffset.top;
- }else{
- thisOffset = $(this).next().offset();
- left = thisOffset.left - directionDiv.width();
- top = thisOffset.top;
- }
- }
- directionDiv.removeClass().addClass(className);
- directionDiv.css({height:height, left:left, top:top});
- directionDiv.show();
- },
- onDragLeave:function(e,source){
- $(source).draggable("proxy").removeClass("dg-proxy-right").addClass("dg-proxy-error");
- directionDiv.hide();
- },
- onDrop:function(e,source){
- directionDiv.remove();
- var thisIndex = $(this).index();
- var sourceIndex = $(source).index();
- var sourceCol = new Array();
- $(source).remove();
- $.each($(grid).datagrid("getPanel")
- .find(".datagrid-body tr"),function(index,obj){
- var sourceTd = $(obj).children("td:eq(" + sourceIndex + ")");
- sourceCol.push(sourceTd);
- sourceTd.remove();
- });
- var prev = sourceIndex > thisIndex;
- thisIndex = $(this).index();
- if(prev){
- $(this).before($(source));
- }else{
- $(this).after($(source));
- }
- $.each($(grid).datagrid("getPanel")
- .find(".datagrid-body tr"),function(index,obj){
- var thisTd = $(obj).children("td:eq(" + thisIndex + ")");
- if(prev){
- thisTd.before(sourceCol[index]);
- }else{
- thisTd.after(sourceCol[index]);
- }
- });
- $(grid).datagrid("columnMoving").datagrid("columnHiding");
- }
- });
- });
- }
- });
easyui datagrid 列拖拽2的更多相关文章
- easyui datagrid 列拖拽
首先easyui 它有提供了拖拽的功能Draggable,那我们就可以想 拖拽标题头到另外的标题头上面我们就对datagrid的columns重新绑定一次 并刷新datagrid这个功能不就行了? & ...
- easyui datagrid列拖拽
<script type="text/javascript"> var cols = [{ field: 'testName', title: '<span cl ...
- easyui datagrid 列隐藏和显示
easyui datagrid 列隐藏和显示 用js怎么控制列的显示和隐藏? 最佳答案 $('#grid').datagrid('hideColumn','列field');把hideColu ...
- js控制easyui datagrid列的显示和隐藏
easyui datagrid 列隐藏和显示 $('#grid').datagrid('hideColumn','列field'); //把hideColumn换成showColumn 即为显示列
- easyui树节点拖拽排序的存储过程
easyui树的拖拽排序功能 easyui树中有拖拽功能 树结构如下: 一个行政区域对应一个单位,一个单位对应多个部门,每个部门下有相关人员,功能要求: (1)行政区域没有子节点,点击text加载部门 ...
- 在 Element-UI 的 Table 组件上添加列拖拽效果
Element-UI 的 Table组件很强大,但是我们的需求更强大... 简单粗暴的来一发效果图: 一.数据驱动 传统的拖动效果,都是基于通过 mousedown.mousemove.mouseup ...
- 列拖拽顺序调整-sortable.js使用
最近在做一个单表统计功能,涉及到一个查询列配置,但是查询出来的列顺序,可以进行配置,通过写列的排序当然阔以,但是方法就不美丽了.所以,在网上搜了一下拖拽的组件,最终定位Sortable.js,简单易用 ...
- 让jquery easyui datagrid列支持绑定嵌套对象
嵌套对象是指返回的json数据,是对象的某个属性自带有属性.而我们恰恰又需要这个属性,默认情况下easyui的datagrid是不支持绑定嵌套对象的.比如:datagrid的field属性只能为fie ...
- easyUI datagrid 列宽自适应(简单 图解)(转)
响应数据格式: easyUI在html代码中结构: 发现了什么没有,我们的表头其实是一个td在td中有一个属性field那么我们就可以获得了; 以下就是自适应代码: //添加事件 function c ...
随机推荐
- 转】MyEclipse使用总结——MyEclipse文件查找技巧
原博文出自于:http://www.cnblogs.com/xdp-gacl/p/3781749.html 感谢! 一.查找文件 使用快捷键[ctrl+shift+R]弹出弹出文件查找框,如下图所示: ...
- HD2086A1 = ?
Problem Description 有如下方程:Ai = (Ai-1 + Ai+1)/2 - Ci (i = 1, 2, 3, .... n). 若给出A0, An+1, 和 C1, C2, .. ...
- C# 多线程参数的使用
一个参数: Thread.Start方法可以带一个参数: public static void Main() { Thread t = new Thread(new ParameterizedThre ...
- find命令之xargs
在使用 find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行.但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出 ...
- HDU 5708 Alice and Bob (博弈,找规律)
题意: 一个无限大的棋盘,一开始在1,1,有三种移动方式,(x+1,y)(x,y+1) (x+k,y+k)最后走到nm不能走了的人算输.. 析:.我们看成一开始在(n,m),往1,1,走,所以自然可以 ...
- libev笔记
libev是一个开源库,实现了一个reactor模式事件驱动任务调度库.代码非常精简,包含所有实现的.c文件只有不到5000行. 支持的事件类型: ev_io ev_timer ev_periodic ...
- C++100款开源界面库[转]
(声明:Alberl以后说到开源库,一般都是指著名的.或者不著名但维护至少3年以上的.那些把代码一扔就没下文的,Alberl不称之为开源库,只称为开源代码.这里并不是贬低,像Alberl前面那个系列的 ...
- 使用.NET中的Action及Func泛型委托
委托,在C#编程中占有极其重要的地位,委托可以将函数封装到委托对象中,并且多个委托可以合并为一个委托,委托对象则可以像普通对象一样被存储.传递,之后在任何时刻进行调用,因此,C#中函数回调 ...
- 如何在KVM中管理存储池
来自:http://blog.csdn.net/my2005lb/article/details/8635661 KVM平台以存储池的形式对存储进行统一管理,所谓存储池可以理解为本地目录.通过远端磁盘 ...
- registerClassAlias()函数和getClassByAlias()函数
flash.net 包中包含包级函数,可用于打开新的浏览器窗口,向服务器发送 URL 请求以及处理类别名. registerClassAlias()函数 public function registe ...