jQuery Easyui 비동기 로딩 트리 문제 분석

高洛峰
풀어 주다: 2016-12-29 13:29:06
원래의
1246명이 탐색했습니다.

로컬에서 json 파일을 로드하고 이벤트를 통해 ul에 동적으로 삽입하려고 하는데 작은 버그가 발생했습니다

html의 코드는 이렇습니다

<ul class="easyui-tree" id="tt"></ul>
로그인 후 복사

Code in 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(&#39;find&#39;, nodeID);
if(node){
$("#tt").tree(&#39;select&#39;, 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
});
}
로그인 후 복사

처음에는 버튼 클릭 이벤트를 통해 트리의 내용을 동적으로 로드하고 싶었습니다. 위의 코드에서 addAttr2Tree는 버튼 클릭에 해당하는 로컬 json 데이터를 html의 ul 태그에 추가하는 데 사용되며,changeImgSrc는 일부 트리 노드를 선택하고 이미지를 로드하는 데 사용되지만 디버깅 방법에 관계없이 항상 오류가 나타납니다.

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

속성 속성을 획득할 수 없습니다! ! ! 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 비동기 로딩 트리 문제에 대한 분석입니다. 궁금한 사항이 있으면 메시지를 남겨주시면 에디터가 답변해 드리겠습니다. 당신은 시간에. 또한 PHP 중국어 웹사이트를 지원해 주신 모든 분들께 감사드립니다!

jQuery Easyui 비동기 트리 로딩 문제 분석 관련 기사를 더 보려면 PHP 중국어 웹사이트를 주목하세요!


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿