关于今天easyui的坑 DateGrid兼容$ref问题,版本easyui 1.2.2

来源:互联网 发布:淘宝11销量排行 编辑:程序博客网 时间:2024/06/05 20:59

总结了一下,我从开始接触easyui每天都在爬坑,今天也不例外,今天这个主要是把easyui的js修改了一下,所以记录一下,省的忘记

今天遇到了一个问题,就是我后台红的hibernate 以及alibaba的json做的json返回,用过的人都知道这会出现$ref错误,

需要用前端的一个js来反编译一下

一下是前端的反编译代码,原文忘记是在哪位前端大神那里找来的了以下是js

var FastJson = {isArray : function(a) {return "object" == typeof a&& "[object array]" == Object.prototype.toString.call(a).toLowerCase();},isObject : function(a) {return "object" == typeof a&& "[object object]" == Object.prototype.toString.call(a).toLowerCase();},format : function(a) {if (null == a)return null;"string" == typeof a && (a = eval("(" + a + ")"));return this._format(a, a, null, null, null);},_randomId : function() {return "randomId_" + parseInt(1E9 * Math.random());},_getJsonValue : function(a, c) {var d = this._randomId(), b;b = "" + ("function " + d + "(root){") + ("return root." + c + ";");b += "}";b += "";var e = document.createElement("script");e.id = d;e.text = b;document.body.appendChild(e);d = window[d](a);e.parentNode.removeChild(e);return d},_format : function(a, c, d, b, e) {d || (d = "");if (this.isObject(c)) {if (c.$ref) {var g = c.$ref;0 == g.indexOf("$.")&& (b[e] = this._getJsonValue(a, g.substring(2)));return}for ( var f in c)b = d, "" != b && (b += "."), g = c[f], b += f, this._format(a, g, b, c, f);} else if (this.isArray(c))for (f in c)b = d, g = c[f], b = b + "[" + f + "]", this._format(a, g,b, c, f);return a}};
我开始是想找找easyui DateGrid有没有在接受数据之后就执行的方法,然后我找了一下api发现有,可是可能是版本太低的原因,并没有起作用,所以

我是把这段代码粘贴到了jquery.easyui.min.1.2.2.js里面,放到最下面就行了

然后需要在js里面找到$.fn.datagrid.defaults开头的一个datagrid默认属性的构造器

添加一个新的属性,我的叫isFastJson

然后在$.fn.datagrid.parseOptions开头的配置文件读取方法中加上读取你的配置的方法

//替换属性isFastJson:(t.attr("isFastJson") ? t.attr("isFastJson") == "true" : undefined),

大概就是这个样子,然后还需要最后一步,就是当dataGrid得到返回的数据时判断是不是需要格式化

function _482() {$.ajax({type : opts.method,url : opts.url,data : _480,dataType : "json",success : function(data) {if(opts.isFastJson)FastJson.format(data);setTimeout(function() {_483();}, 0);_3f6(_47d, data);setTimeout(function() {_46f(_47d);}, 0);},error : function() {setTimeout(function() {_483();}, 0);if (opts.onLoadError) {opts.onLoadError.apply(_47d, arguments);}}});}

可能因为版本不一样所以会有所差异,但是应该也是可以找到的

然后在dataGrid生成时加上该属性就行。需要格式化赋值true 不需要时赋值false

datagrid({title:'统计列表' ,fit : false,dataType : 'json',striped : true, //奇偶行是否区分singleSelect : true, //单选模式rownumbers : true, //行号isFastJson : true,loadMsg: '数据正在加载,请耐心的等待...' ,

至此,$ref问题已经解决了,可能高版本就可以通过别的方法来结局了,这个版本我没有找到拦截数据的地方,如果有人知道,欢迎指导



0 0
原创粉丝点击