扩展jquery easyui datagrid编辑单元格

1.随便聊聊

  这段时间由于工作上的业务需求,对jquery easyui比较感兴趣,根据比较浅薄的js知识,对jquery easyui中的datagrid的源码进行解读,想从中扩展一些实用方法出来.初次打开源码拜读时,呜呼呀,(用东北话说就是,哎呀妈呀),介些都是啥子玩意啊?原来,我从晚上下载的是min版的,众所周知,min版即为压缩版那啊,不过我先前以为只是将空格和回车删除掉了.出乎意料的是并非如此,各位请看:

 1 function _195(_196, _197) {  
 2     var opts = $.data(_196, "progressbar").options;  
 3     var bar = $.data(_196, "progressbar").bar;  
 4     if (_197) {  
 5         opts.width = _197;  
 6     }  
 7     bar._outerWidth(opts.width)._outerHeight(opts.height);  
 8     bar.find("div.progressbar-text").width(bar.width());  
 9     bar.find("div.progressbar-text,div.progressbar-value").css({height: bar.height() + "px", lineHeight: bar.height() + "px"});  
10 }; 

  以上是我摘自1.8.0版本中的一段代码.可以看出,排版后仍然无法很轻易地阅读.在此插一句,如果各位谁有非min版本,请告之在下,在此感谢!

2.知识梳理

  不过,在此也要告诉大家一个好消息,在本人的悉心研究下,已经有了重大突破!(怎么像发布会,抱歉抱歉),现在就将实践经验和代码呈上,请各位赐教!我所做的扩展是对单元格的操作,目前仅仅扩展了两个方法:beginEditCell和endEditCell,参照beginEdit和endEdit两个方法而来,有所改动还需完善.后者两个方法可以参照API,分别表示开始编辑一行和结束编辑一行,很显然这是针对可编辑的datagrid而言的.
  扩展jquery有一个基本的框架,在这个框架之内是很普通写js代码是一样的的.下面看这个框架:

 1 (function ($) {  
 2     $.extend($.fn.datagrid.methods, {  
 3         beginEditCell: function (target, options) {  
 4             return target.each(function () {  
 5                 beginEditCell(this, options);  
 6             });  
 7         },  
 8         endEditCell: function (target, options) {  
 9             return target.each(function () {  
10                 endEditCell(this, options);  
11             });  
12         }  
13     });  
14 })(jQuery); 

  其中,代码中的beginEditCell和endEditCell就是我写的扩展方法,前者是开始编辑单元格,后者是结束编辑单元格. 下面简单介绍一下,juqery使用的引擎是sizzle,sizzle可以为你提供多元素操作,这也就是我提供的基本框架中有each的缘故了,并且还有将该元素返回,以便实现级联处理的效果.下面就把完整的代码展示出来,不做过多的解释,因为其中比较复杂,一一注释比较繁琐,不过有时间我会加上的.

  1 (function ($) {  
  2   
  3     //开启编辑单元格状态  
  4     function beginEditCell(target, options) {  
  5   
  6         var opts = $.data(target, "datagrid").options;  
  7         var tr = opts.finder.getTr(target, options.index);  
  8         var row = opts.finder.getRow(target, options.index);  
  9   
 10 //        //暂时还不知道该代码的含义,忽略使用  
 11 //        if (tr.hasClass("datagrid-row-editing")) {  
 12 //            return;  
 13 //        }  
 14 //        tr.addClass("datagrid-row-editing");  
 15   
 16         _initCellEditor(target, options.index, options.field);  
 17         _outerWidthOfEditable(target);  
 18         //$.validateRow(target, options.index);暂时先不使用,不知道该方法作用  
 19     }  
 20   
 21     function _initCellEditor(target, _index, _field) {  
 22         var opts = $.data(target, "datagrid").options;  
 23         var tr = opts.finder.getTr(target, _index);  
 24         var row = opts.finder.getRow(target, _index);  
 25   
 26         tr.children("td").each(function () {  
 27             var cell = $(this).find("div.datagrid-cell");  
 28             var field = $(this).attr("field");  
 29   
 30             if (field == _field) {//找到与传递参数相同field的单元格  
 31                 var col = $(target).datagrid("getColumnOption", field);  
 32                 if (col && col.editor) {  
 33                     var editorType, editorOp;  
 34                     if (typeof col.editor == "string") {  
 35                         editorType = col.editor;  
 36                     } else {  
 37                         editorType = col.editor.type;  
 38                         editorOp = col.editor.options;  
 39                     }  
 40                     var editor = opts.editors[editorType];  
 41                     if (editor) {  
 42                         var html = cell.html();  
 43                         var outerWidth = cell._outerWidth();  
 44                         cell.addClass("datagrid-editable");  
 45                         cell._outerWidth(outerWidth);  
 46                         cell.html("<table border="0" cellspacing="0" cellpadding="1"><tr><td></td></tr></table>");  
 47                         cell.children("table").bind(  
 48                             "click dblclick contextmenu",  
 49                             function (e) {  
 50                                 e.stopPropagation();  
 51                             });  
 52                         $.data(cell[0], "datagrid.editor", {  
 53                             actions: editor,  
 54                             target: editor.init(cell.find("td"),  
 55                                 editorOp),  
 56                             field: field,  
 57                             type: editorType,  
 58                             oldHtml: html  
 59                         });  
 60                     }  
 61                 }  
 62   
 63                 tr.find("div.datagrid-editable").each(function () {  
 64                     var field = $(this).parent().attr("field");  
 65                     var ed = $.data(this, "datagrid.editor");  
 66                     ed.actions.setValue(ed.target, row[field]);  
 67                 });  
 68             }  
 69         });  
 70     }  
 71   
 72     //为可编辑的单元格设置外边框  
 73     //来自jquery.easyui.1.8.0.js的 function _4d8()方法  
 74     function _outerWidthOfEditable(target) {  
 75         var dc = $.data(target, "datagrid").dc;  
 76         dc.view.find("div.datagrid-editable").each(function () {  
 77             var _this = $(this);  
 78             var field = _this.parent().attr("field");  
 79             var col = $(target).datagrid("getColumnOption", field);  
 80             _this._outerWidth(col.width);  
 81             var ed = $.data(this, "datagrid.editor");  
 82             if (ed.actions.resize) {  
 83                 ed.actions.resize(ed.target, _this.width());  
 84             }  
 85         });  
 86     }  
 87   
 88     //关闭编辑单元格状态  
 89     function endEditCell(target, options) {  
 90         var opts = $.data(target, "datagrid").options;  
 91   
 92         var updatedRows = $.data(target, "datagrid").updatedRows;  
 93         var insertedRows = $.data(target, "datagrid").insertedRows;  
 94   
 95         var tr = opts.finder.getTr(target, options.index);  
 96         var row = opts.finder.getRow(target, options.index);  
 97   
 98 //        //与beginEditCell相呼应,暂时取消  
 99 //        if (!tr.hasClass("datagrid-row-editing")) {//行不能编辑时,返回  
100 //            return;  
101 //        }  
102 //        tr.removeClass("datagrid-row-editing");  
103   
104         var _535 = false;  
105         var _536 = {};  
106         tr.find("div.datagrid-editable").each(function () {  
107             var _537 = $(this).parent().attr("field");  
108             var ed = $.data(this, "datagrid.editor");  
109             var _538 = ed.actions.getValue(ed.target);  
110             if (row[_537] != _538) {  
111                 row[_537] = _538;  
112                 _535 = true;  
113                 _536[_537] = _538;  
114             }  
115         });  
116         if (_535) {  
117             if (_45f(insertedRows, row) == -1) {  
118                 if (_45f(insertedRows, row) == -1) {  
119                     updatedRows.push(row);  
120                 }  
121             }  
122         }  
123   
124         _destroyCellEditor(target, options);  
125         $(target).datagrid("refreshRow", options.index);  
126         opts.onAfterEdit.call(target, options.index, row, _536);  
127     }  
128   
129     function _45f(a, o) {  
130         for (var i = 0, len = a.length; i < len; i++) {  
131             if (a[i] == o) {  
132                 return i;  
133             }  
134         }  
135         return -1;  
136     }  
137   
138     //销毁单元格编辑器  
139     function _destroyCellEditor(target, options) {  
140   
141         var opts = $.data(target, "datagrid").options;  
142         var tr = opts.finder.getTr(target, options.index);  
143   
144         tr.children("td").each(function () {  
145             var field = $(this).attr("field");  
146   
147             if (field == options.field) {//找到与传递参数相同field的单元格  
148   
149                 var cell = $(this).find("div.datagrid-editable");  
150                 if (cell.length) {  
151                     var ed = $.data(cell[0], "datagrid.editor");  
152                     if (ed.actions.destroy) {  
153                         ed.actions.destroy(ed.target);  
154                     }  
155                     cell.html(ed.oldHtml);  
156                     $.removeData(cell[0], "datagrid.editor");  
157                     cell.removeClass("datagrid-editable");  
158                     cell.css("width", "");  
159                 }  
160             }  
161         });  
162     }  
163   
164     $.extend($.fn.datagrid.methods, {  
165         beginEditCell: function (target, options) {  
166             return target.each(function () {  
167                 beginEditCell(this, options);  
168             });  
169         },  
170         endEditCell: function (target, options) {  
171             return target.each(function () {  
172                 endEditCell(this, options);  
173             });  
174         }  
175     });  
176 })(jQuery);  
View Code

  测试页面也展示出来,方便大家使用,不过需要加上必需的jquery easyui代码:

  1 <!DOCTYPE html>  
  2 <html>  
  3 <head>  
  4     <meta charset="UTF-8">  
  5     <title>Row Editing DataGrid - jQuery EasyUI Demo</title>  
  6     <link rel="stylesheet" type="text/css" href="../../themes/default/easyui.css">  
  7     <link rel="stylesheet" type="text/css" href="../../themes/icon.css">  
  8     <link rel="stylesheet" type="text/css" href="../demo.css">  
  9     <script type="text/javascript" src="../../jquery-1.8.0.js"></script>  
 10     <script type="text/javascript" src="../../jquery.easyui.min.js"></script>  
 11     <script type="text/javascript" src="../../plugins/jquery.datagrid.cellextend.js"></script>  
 12     <script type="text/javascript">  
 13         $(document).ready(function(){  
 14             $("#dg").datagrid({  
 15                 rownumbers:true,  
 16                 iconCls: 'icon-edit',  
 17                 singleSelect: true,  
 18                 toolbar: '#tb',  
 19                 url: '../datagrid/datagrid_data1.json',  
 20                 onDblClickCell: onClickRow,  
 21                 onAfterEdit:onAfterEdit,  
 22                 striped:true,  
 23                 columns:[[  
 24                     {field: 'itemid', title: 'Item ID',  80, fitColumns: true},  
 25                     {field: 'productid', title: 'Product',  100,  
 26                         formatter: function (value, row) {  
 27                             return row.productname;  
 28                         },  
 29                         editor: {  
 30                             type: 'combobox',  
 31                             options: {  
 32                                 valueField: 'productid',  
 33                                 textField: 'productname',  
 34                                 url: '../datagrid/products.json',  
 35                                 required: true  
 36                             }  
 37                         }},  
 38                     {field: 'listprice', title: 'List Price',  80, align: 'right', editor: {type: 'numberbox', options: {precision: 1}}},  
 39                     {field: 'unitcost', title: 'Unit Cost',  80, align: 'right', editor: 'numberbox'},  
 40                     {field: 'attr1', title: 'Attribute',  250, editor: 'text'},  
 41                     {field: 'status', title: 'Status',  60, align: 'center', editor: {type: 'checkbox', options: {on: 'P', off: ''}}},  
 42                     {field: 'link', title: 'Link',  60, align: 'center',  
 43                         formatter: function (value, rowData, rowIndex) {  
 44                             return "<a href='" + value.href + "' onclick='test(" + rowIndex + ");return false;'>" + value.text + "</a>"  
 45                         }  
 46                     },  
 47                     {field: 'isFamle', title: 'IsFamle',  60, align: 'center',  
 48                         formatter: function (value, rowData, rowIndex) {  
 49                             var str = value=="true" ? "checked" : "";  
 50                             return "<input type='checkbox' " + str + ">";  
 51                             //return "<a href='" + value.href + "' onclick='test(" + rowIndex + ");return false;'>" + value.text + "</a>"  
 52                         }  
 53                     }  
 54                 ]]  
 55             });  
 56         });  
 57   
 58         function test(obj){  
 59             alert(obj);  
 60         }  
 61     </script>  
 62 </head>  
 63 <body>  
 64 <h2>Row Editing DataGrid</h2>  
 65   
 66 <div class="demo-info">  
 67     <div class="demo-tip icon-tip"></div>  
 68     <div>Click the row to start editing.</div>  
 69     <a href="#">asdf</a>  
 70 </div>  
 71 <div style="margin:10px 0;"></div>  
 72   
 73 <table id="dg" class="easyui-datagrid" title="Row Editing DataGrid" style="800px;height:auto">  
 74     <thead>  
 75     <tr>  
 76   
 77     </tr>  
 78     </thead>  
 79 </table>  
 80   
 81 <script type="text/javascript">  
 82   
 83     var _rowIndex = undefined;  
 84     var _field = undefined;  
 85   
 86     function endEditing() {  
 87         if (_rowIndex == undefined || _field == undefined) {  
 88             return true;  
 89         }  
 90   
 91         $('#dg').datagrid('endEditCell', {index: _rowIndex, field: _field});  
 92         _rowIndex = undefined;  
 93         _field = undefined;  
 94         return true;  
 95     }  
 96   
 97     function onClickRow(rowIndex, field, value) {  
 98         //$('#dg').datagrid('beginEdit', rowIndex);  
 99         //$('#dg').datagrid('getEditors', rowIndex);  
100         if (_rowIndex != rowIndex || _field != field) {  
101   
102             if (endEditing()){  
103                 $('#dg').datagrid('beginEditCell', {index: rowIndex, field: field});  
104                 _rowIndex = rowIndex;  
105                 _field = field;  
106             }  
107   
108         }  
109   
110         var data = $('#dg').datagrid('getSelected');  
111 //        alert(data.link.href);  
112     }  
113     function onAfterEdit(rowIndex, rowData, changes){  
114   
115         if(changes.status=="P"){  
116             rowData["attr1"]="12312312";  
117             $('#dg').datagrid('updateRow',{  
118                 index: rowIndex,  
119                 row: rowData  
120             });  
121   
122             $('#dg').datagrid('acceptChanges');  
123             var data = $('#dg').datagrid('getSelected');  
124             alert(data.status);  
125         }else if(changes.status==""){  
126             rowData["attr1"]="12312312";  
127             $('#dg').datagrid('updateRow',{  
128                 index: rowIndex,  
129                 row: rowData  
130             });  
131   
132             $('#dg').datagrid('acceptChanges');  
133             var data = $('#dg').datagrid('getSelected');  
134             alert(data.status);  
135             alert(data.attr1);  
136         }  
137     }  
138 </script>  
139 </body>  
140 </html>  
View Code

  感谢大家阅读,请多指教!谢谢

原文地址:https://www.cnblogs.com/geyifan/p/3276364.html