转自   http://blog.csdn.net/tianlincao/article/details/7494467

前言

JQuery easyUi datagrid 中 使用datagrid生成数据列表后,需要在每一行加入一个操作按钮列,按钮在默认非编辑状态下是不显示的,需要激活行编辑状态下才显示,故不能再formatter处理,需要使用自定义按钮来处理了。

解决方法

第一步:新增自定义编辑器

自定义编辑器在 jquery.easyui.extend.js 增加,需要实现编辑器的4个默认方法,如下:
  1. $.extend($.fn.datagrid.defaults.editors, {
  2. delEdit : {
  3. init: function(container, options)
  4. {
  5. var editorContainer = $('<div/>');
  6. var button = $("<a href='javascript:void(0)'></a>")
  7. .linkbutton({plain:true, iconCls:"icon-remove"});
  8. editorContainer.append(button);
  9. editorContainer.appendTo(container);
  10. return button;
  11. },
  12. getValue: function(target)
  13. {
  14. return $(target).text();
  15. },
  16. setValue: function(target, value)
  17. {
  18. $(target).text(value);
  19. },
  20. resize: function(target, width)
  21. {
  22. var span = $(target);
  23. if ($.boxModel == true){
  24. span.width(width - (span.outerWidth() - span.width()) - 10);
  25. } else {
  26. span.width(width - 10);
  27. }
  28. }
  29. }
  30. });

这是我新增的一个删除按钮编辑框,按钮用的是easyui的linkbutton,图标样式是icon-remove。

第二步:绑定自定义编辑器

自定义编辑器定义好后,我们在 datagrid的 columns 中增加一列field:
  1. {field:'actionColumn',title:'<%/*自定义删除按钮*/%>',width:20,align:'center',editor:'delEdit'}

actionColumn是json中的列属性,title可以为空或者自己命名,editor指定为自定义的编辑器。

 
接下来我们要让编辑器绑定函数,就要在datagrid触发行编辑的方法中,加入自定义函数:setEditing:
  1. onClickRow:function(rowIndex, rowData){
  2. if(rowIndex == lastIndex)
  3. {
  4. $('#workloadTable').datagrid('endEdit', lastIndex);
  5. lastIndex = -999;
  6. }
  7. else
  8. {
  9. $('#workloadTable').datagrid('endEdit', lastIndex);
  10. $('#workloadTable').datagrid('beginEdit', rowIndex);
  11. $('#workloadTable').datagrid('endEdit', lastIndex);
  12. //增加完成情况字数输入限制
  13. $('#workloadTable').datagrid('beginEdit', rowIndex);
  14. var ed = $('#workloadTable').datagrid('getEditors', rowIndex);
  15. for (var i = 0; i < ed.length; i++)
  16. {
  17. var e = ed[i];
  18. if(e.field == "description")
  19. {
  20. $(e.target).bind("keyup",function()
  21. {
  22. return countChar($(this));
  23. }).bind("change", function()
  24. {
  25. return countChar($(this));
  26. });
  27. }
  28. }
  29. setEditing(rowIndex, rowData);
  30. lastIndex = rowIndex;
  31. }
  32. }

setEditing 就是行编辑器的重构函数,代码如下:

  1. /**
  2. * 重构行编辑器
  3. * @param rowIndex
  4. */
  5. function setEditing(rowIndex, rowData){
  6. var editors = $('#workloadTable').datagrid('getEditors', rowIndex);
  7. var delEditor = editors[3];      // 删除按钮
  8. var delReportButton = delEditor.target;
  9. delReportButton.attr("title",'<%/*删除完成情况*/%><bean:message key="task.workloadnew.addreportbyday.jsp.message003"/>').linkbutton({iconCls:"icon-remove"});
  10. delReportButton.bind("click",function()
  11. {
  12. if(!rowData)
  13. {
  14. return;
  15. }
  16. deleteLog(rowData);  // 删除日志
  17. });
  18. }

这就为我们的delEditor 绑定了click方法,此处也可以绑定其他行编辑框的方法,比如输入字数限制,值设置等。

最后

至此,可以生成列表操作按钮列了。

JQuery easyUi datagrid 中 自定义editor作为列表操作按钮列的更多相关文章

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

    前言 近来项目中使用到 easyui 来进行页面设计,感觉挺方便的,但是网上除了api外,其他有价值的资料比较少,故在此分享一点经验,供大家参考.   问题 JQuery easyUi datagri ...

  2. [WPF]GridView或DataGrid中自定义样式:依据某一列设定其对应行的样式(背景色,字体等)

    附效果照一张: 本方法使用StyleSelector来 获得依据自定义逻辑的style. ① class ConditionalStyleSelector : StyleSelector { publ ...

  3. jquery easyui datagrid设置可编辑行的某个列不可编辑

    function onClickRowd(index1, field1) { if (editIndexd != index1) { if (endEditing()) { $('#dg').data ...

  4. jquery easyui datagrid 无滚动条,datagrid 没垂直滚动条

    jquery easyui datagrid 无滚动条,datagrid 没垂直滚动条 ============================== 蕃薯耀 2018年2月6日 http://www. ...

  5. 扩展jquery easyui datagrid编辑单元格

    扩展jquery easyui datagrid编辑单元格 1.随便聊聊 这段时间由于工作上的业务需求,对jquery easyui比较感兴趣,根据比较浅薄的js知识,对jquery easyui中的 ...

  6. 雷林鹏分享:jQuery EasyUI 数据网格 - 自定义分页

    jQuery EasyUI 数据网格 - 自定义分页 数据网格(datagrid)内置一个很好特性的分页功能,自定义也相当简单.在本教程中,我们将创建一个数据网格(datagrid),并在分页工具栏上 ...

  7. jquery easyui datagrid使用参考

    jquery easyui datagrid使用参考   创建datagrid 在页面上添加一个div或table标签,然后用jquery获取这个标签,并初始化一个datagrid.代码如下: 页面上 ...

  8. Jquery easyui datagrid 导出Excel

    From:http://www.cnblogs.com/weiqt/articles/4022399.html datagrid的扩展方法,用于将当前的数据生成excel需要的内容. 1 <sc ...

  9. 雷林鹏分享:jQuery EasyUI 数据网格 - 自定义排序

    jQuery EasyUI 数据网格 - 自定义排序 如果默认的排序行为不满足您的需求,您可以自定义数据网格(datagrid)的排序行为. 最基础的,用户可以在列上定义一个排序函数,函数名是 sor ...

随机推荐

  1. spring ehcache 使用详解

    Spring 整合 Ehcache 管理缓存详解  yellowbutterfly 前言 Ehcache 是一个成熟的缓存框架,你可以直接使用它来管理你的缓存. Spring 提供了对缓存功能的抽象: ...

  2. bootstrapValidator 重置表单

    最近在公司做业务系统后台,用的js框架还是jquery  ui框架 是以bootstrap为基础的beyondadmin-v1.4.s3这套,用起来还挺不错,所以公司所有的后台ui都使用这套.这套ui ...

  3. redis---安全设置

    redis的安全性是通过设置口令来实现的. 首先打开redis的配置文件,我的是在/etc/redis/redis.conf,个人的路径可能会有不同,可以自行查找. 打开redis.conf文件以后, ...

  4. JS案例练习-手机微信聊天对话框

    先附图 CSS部分: <style> body{} *{;} li{list-style: none;} .container{ width:310px; height:600px; ma ...

  5. 使用adbWireless无线调试Android真机设备[转]

    开发Android的朋友都知道,真机调试需要把手机与PC相连,然后把应用部署到真机上进行安装和调试.长长的USB线显得很麻烦,而且如果需要USB接口与其他设备连接的话显得很不方便.今天介绍一种不通过U ...

  6. hihocoder第三十六周 二分查找

    题目链接:http://hihocoder.com/contest/hiho36/problem/1 , 一个比较简单的二分. 算法: 由于数据量比较大,O(nlogn)无法通过,所以不能先排序再查找 ...

  7. Redis基础对象

    Redis 中每个对象都由一个 redisObject 结构表示 typedef struct redisObject { //类型 unsigned type:; //编码 unsigned enc ...

  8. 详解Unity 4.6新UI的布局

    本文所讲的是Unity 4.6中新加入的uGUI,官方称Unity UI,而不是过去的OnGUI式的旧UI(官方称Legacy GUI). 我曾经在8月份对照4.6 Beta的文档写过一篇笔记学习Un ...

  9. World Wind Java开发之十五——加载三维模型(转)

    之前的一篇博客是关于加载粗三维模型的,见http://blog.csdn.net/giser_whu/article/details/43452703,这个地方还存在着不能加载纹理的问题,一直没呢解决 ...

  10. POJ - 3685 Matrix

    二分kth,答案满足的条件为:m ≤ 小于等于x的值数cntx.x和cntx单调不减,随着x增大,条件成立可表示为:0001111. 本地打一个小型的表可以发现列编号j固定时候,目标函数f(i,j)似 ...