关于 jQuery Easyui异步加载tree的问题解析


Posted in Javascript onDecember 06, 2016

想要实现从本地中加载json文件,通过事件来动态的插入到ul中时,遇到了一小bug

html中代码是这样的

<ul class="easyui-tree" id="tt"></ul>

js中的代码

$(".next-menu:nth-child(1) a").click(function() {
var $IDstr = $(this).attr("id"),
$treeIDNum = parseInt($(this).attr("treeID")),
jsonURL = "json/" + $IDstr + ".json",
node;
addAttr2Tree(jsonURL);
changeImgSrc($treeIDNum); 
});
});
function changeImgSrc(nodeID){
var node = $("#tt").tree('find', nodeID);
if(node){
$("#tt").tree('select', node.target);
}
if (node.attributes) {
$("#img-box").attr("src", node.attributes.url);
}
}
function addAttr2Tree(URL){
$("#tt").tree({
url: URL,
method: "get",
animate: true,
lines: true
});
}

起初是想通过一个按钮的点击事件来动态的加载tree的内容就是如上代码,addAttr2Tree 是用来将点击按钮时对应的本地json数据加到html中的ul标签中, changeImgSrc 是对tree节点的一些选中操作以及图片的加载,但是无论怎么调试,总是会出现一条错误

关于 jQuery Easyui异步加载tree的问题解析 

无法获取attributes属性!!!我反复确认attributes是完整无缺的放在json文件里的而且总是第一次点击按钮时才会出现这种错误,第二次及其以后,这种错误是没有的

后来我就想到,是不是因为json数据动态加载的速度比不上程序代码执行的速度?!

果然不出我所料!easyui中tree自带了一个方法onLoadSuccess 当数据成功加载时,才会执行一些操作
所以

$(".next-menu:nth-child(1) a").click(function() {
var $IDstr = $(this).attr("id"),
$treeIDNum = parseInt($(this).attr("treeID")),
jsonURL = "json/" + $IDstr + ".json",
node;
addAttr2Tree(jsonURL);
$("#tt").tree({
onLoadSuccess: function(){
changeImgSrc($treeIDNum);
}
});
});

代码改成这样就可以了。

以上所述是小编给大家介绍的jQuery Easyui异步加载tree的问题解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js去除重复字符串两种实现方法
Jan 09 Javascript
js控制input框只读实现示例
Jan 20 Javascript
node.js中的fs.rmdir方法使用说明
Dec 16 Javascript
IE浏览器下PNG相关功能
Jul 05 Javascript
JS实现禁止鼠标右键的功能
Oct 15 Javascript
基于JS脚本语言的基础语法详解
Jul 22 Javascript
vue-cli项目优化方法- 缩短首屏加载时间
Apr 01 Javascript
vue elementui el-form rules动态验证的实例代码详解
May 23 Javascript
JS+HTML实现自定义上传图片按钮并显示图片功能的方法分析
Feb 12 Javascript
小程序卡片切换效果组件wxCardSwiper的实现
Feb 13 Javascript
在vue中使用防抖函数组件操作
Jul 26 Javascript
如何利用JS将手机号中间四位变成*号
Sep 29 Javascript
JavaScript之Vue.js【入门基础】
Dec 06 #Javascript
浅析JavaScript中作用域和作用域链
Dec 06 #Javascript
利用JS轻松实现获取表单数据
Dec 06 #Javascript
手机移动端实现 jquery和HTML5 Canvas的幸运大奖盘特效
Dec 06 #Javascript
Javascript highcharts 饼图显示数量和百分比实例代码
Dec 06 #Javascript
jQuery EasyUI 获取tabs的实例解析
Dec 06 #Javascript
如何防止INPUT按回车自动提交表单FORM
Dec 06 #Javascript
You might like
《OVERLORD》第四季,终于等到你!
2020/03/02 日漫
PHP入门之常量简介和系统常量
2014/05/12 PHP
主流PHP框架的优缺点对比分析
2014/12/25 PHP
静态html文件执行php语句的方法(推荐)
2016/11/21 PHP
PHP用正则匹配form表单中所有元素的类型和属性值实例代码
2017/02/28 PHP
出现“不能执行已释放的Script代码”错误的原因及解决办法
2007/08/29 Javascript
Jquery $.getJSON 在IE下的缓存问题解决方法
2014/10/10 Javascript
原生JS版和jquery版实现checkbox的全选/全不选/点选/行内点选(Mr.Think)
2016/10/29 Javascript
JavaScript判断浏览器对CSS3属性是否支持的多种方法
2016/11/13 Javascript
实例分析nodejs模块xml2js解析xml过程中遇到的坑
2017/03/18 NodeJs
JavaScript中的FileReader图片预览上传功能实现代码
2017/07/24 Javascript
浅谈Node 调试工具入门教程
2018/03/20 Javascript
SVG实现时钟效果
2018/07/17 Javascript
JavaScript栈和队列相关操作与实现方法详解
2018/12/07 Javascript
微信小程序实现文字从右向左无限滚动
2020/11/18 Javascript
js 实现 list转换成tree的方法示例(数组到树)
2019/08/18 Javascript
vue 通过base64实现图片下载功能
2020/12/19 Vue.js
[58:37]Serenity vs Fnatic 2018国际邀请赛淘汰赛BO1 8.21
2018/08/22 DOTA
使用python Django做网页
2013/11/04 Python
浅谈Python单向链表的实现
2015/12/24 Python
python实现多层感知器MLP(基于双月数据集)
2019/01/18 Python
python用match()函数爬数据方法详解
2019/07/23 Python
Django中提供的6种缓存方式详解
2019/08/05 Python
Python3.7 读取音频根据文件名生成脚本的代码
2020/04/07 Python
python2.7使用scapy发送syn实例
2020/05/05 Python
Keras loss函数剖析
2020/07/06 Python
python 读取、写入txt文件的示例
2020/09/27 Python
CSS3感应鼠标的背景闪烁和图片缩放动画效果
2014/05/14 HTML / CSS
css3 伪元素和伪类选择器详解
2014/09/04 HTML / CSS
英国口碑最好的的维他命胶囊品牌:Myvitamins(有中文站)
2016/12/03 全球购物
体育专业个人的求职信范文
2013/09/21 职场文书
检举信的格式及范文
2014/04/04 职场文书
先进基层党组织材料
2014/12/25 职场文书
品德与社会教学反思
2016/02/24 职场文书
经典人生语录分享:不畏将来,不念过去,笑对当下
2019/12/12 职场文书
pytorch 如何使用batch训练lstm网络
2021/05/28 Python