转自   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. JavaScript初识(二)

    接上一篇: 九丶伪数组 arguments arguments代表的是实参.有个讲究的地方是:arguments只在函数中使用 (1)返回函数实参的个数:arguments.length fn(2,4 ...

  2. spring ajax以及页面返回中文乱码问题解决

    在spring配置文件中添加 <!--返回中文乱码--> <mvc:annotation-driven > <!-- 消息转换器 --> <mvc:messa ...

  3. vue2.0 vue-cli+webpack使用less和scss的说明

    config 目录下好像都不需要相关配置,但是package.json里面 使用less cnpm install --save-dev less less-loader //下面不需要配置,可省略 ...

  4. angular 学习笔记(3) ng-repeat遍历json并且给样式

    视图: <div ng-app="myapp" ng-controller="myctrl"> <ul> <li ng-repea ...

  5. Error和Exception的区别?

    Error和Exception都继承自Throwable类 二者不同之处在于: Exception: 1.可以是可控制的(checked)或是不可控制的(unchecked) 2.表示一个有程序员编写 ...

  6. 碎碎念css

    块状元素单独占一行,但加上float变成跟着别人,有空就插!float让块级元素变行内元素

  7. 五、c++实现离散傅里叶变换

    C++离散傅里叶变换 一.序言: 该教程基于之前的图像处理类MYCV,是对其的补充. 二.设计目标 对图像进行简单的离散傅里叶变换,并输出生成的频谱图. 三.需要提前掌握的知识 二维傅里叶变换公式: ...

  8. [Hack] 搭建渗透测试实验环境

    安装虚拟机镜像,镜像如下: Kali-Linux-2016.1-vm-amd64(https://www.kali.org/) Metasploitable2-Linux(https://source ...

  9. linux 命令——34 du(转)

    Linux du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的. 1.命令格式: du [选项][文件] 2.命令功能 ...

  10. 【BZOJ3925】[ZJOI2015] 地震后的幻想乡(状压期望DP)

    点此看题面 大致题意: 有\(n\)个点和\(m\)条边,每条边的权值是一个\(0\sim1\)的随机实数,要你用\(n-1\)条边将图联通,问这\(n-1\)条边中边权最大值的期望最小值. 提示 这 ...