博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jeasyui 造成$.data(...) is undefined报错的原因及解决
阅读量:6326 次
发布时间:2019-06-22

本文共 1063 字,大约阅读时间需要 3 分钟。

一、没有正常调用html渲染方法。

【错误代码】

var panel = $('
');panel.addClass('easyui-tabs');panel.addClass('tabs-container');return panel;

【正确代码】

var panel = $('
');panel.tabs(); // html渲染方法return panel;

// 以下代码纯属理论猜想未经测试var panel = $('
');panel.tabs(); // html渲染方法panel.addClass('easyui-tabs');$.parser.parse(panel);return panel;

【注解】

1) 添加class='easyui-tabs'并不能直接引起panel.tabs()方法的执行,只有调用$.parser.parse()解析class='easyui-tabs'才会调用panel.tabs()。
2) jeasyui的document.ready()方法中已调用$.parser.parse()方法,所以一般我们在html中写class='easyui-tabs'时不需要再调用$.parser.parse()方法。(通过ajax动态添加的html需要调用$.parser.parse(context)方法才能正常渲染。)

 

二、使用子类时的bug。

【说明】

如使用propertygrid时会出现“$.data(_44e, "datagrid") is undefined”的报错,就是因为easyui设置data时使用的是propertygrid,调用父类datagrid的方法时获取data使用的是datagrid。这个似乎是easyui的bug,遇到了只能改源码了。

 

三、代码执行顺序错误。

【说明】

这个问题的根源和第一条其实是一样的,也是没有正常调用html渲染方法。虽然代码上看是正常调用了,但是报错当时渲染方法还没有执行到。

【解决】

把执行顺序弄对了就行。实在不行就用万恶的setTimeout把会报错的代码的执行顺序直接延迟到最后执行。 

setTimeout(function(){// 要延后执行的代码},0);

 

四、页面更新代码重复执行。

【说明】

这个问题的根源和第一条还是一样的,虽然正常调用了一次html渲染方法,但是页面又被更新到了执行渲染方法前的状态时,就会报错了。此时应想办法解决代码重复执行的问题。

转载地址:http://acmaa.baihongyu.com/

你可能感兴趣的文章
Testng生成的测试报告乱码解决办法
查看>>
vim快速入门
查看>>
大杂烩 -- 单向链表是否存在环或是否相交
查看>>
java中重载与重写的区别
查看>>
mybatis mapper xml文件配置resultmap时,id行和result行有什么区别?
查看>>
关键字检索高亮标出-javasript/jQuery代码实现
查看>>
Vijos P1785 同学排序【模拟】
查看>>
人物关系网络图可视化
查看>>
关于ADO.Net SqlConnection的性能优化
查看>>
docker安装及加速配置
查看>>
Android系统剪切板
查看>>
[2013百度软件研发笔试题] 求字符串中连续出现同样字符的最大值
查看>>
如何来展开項目
查看>>
CSS变量variable
查看>>
MRF能量优化
查看>>
JForum 源码分析
查看>>
【nginx】nginx:利用负载均衡原理实现代码的热部署和灰度发布
查看>>
电子书 VS 纸质书
查看>>
老板雇佣的是40小时的工作量还是普通人需要花40小时才能完成的工作成果?
查看>>
javascript实时保存时出现改动多条记录的bug
查看>>