方法一: 自己做递归函数
function findChildRecursively(rootNode, key, value) {
var nodes = rootNode.childNodes;
for(var i = 0; i < nodes.length; i++) {
if(nodes[i].attributes[key] == value){
return nodes[i];
} else {
if(!nodes[i].isLeaf()) {
continue;
}
if(nodes[i].isLoaded()) {
nodes[i].reload();
}
if(node = findChildRecursively(nodes[i], key, value)) {
return node;
}
}
}
return null;
}
方法二: 利用现成方法 cascade
var node = null;
rootNode.cascade(function(n) {
if(!n.isLeaf() && !n.isLoaded()) {
n.reload();
return true;
}
if(n.attributes[key] == value) {
node = n;
return false;
}
return true;
});
本文转自博客园沉睡森林@漂在北京的博客,原文链接:extjs查找树节点的2种方法,如需转载请自行联系原博主。