JavaScript 循环递归优化问题

代码如下:functionSelectAll(iIndex){vartree;if(iIndex==1)tree=igtree_getTreeById("ulTreeMe... 代码如下:
function SelectAll(iIndex)
{
var tree;
if(iIndex==1)
tree=igtree_getTreeById("ulTreeMenuR");
else
tree=igtree_getTreeById("ulTreeMenuW");
var nodes=tree.getNodes();
for(var i=0;i<nodes.length;i++)
{
nodes[i].setChecked(true);
nodes[i].setExpanded(true);
if(nodes[i].hasChildren())
{
alert(nodes[i].getChildNodes().length);
SelectNode(nodes[i])
}
}
}

function SelectNode(iNode)
{
if(!iNode.hasChildren())
return;
var vNodes=iNode.getChildNodes();
for(var i=0;i<vNodes.length;i++)
{
vNodes[i].setChecked(true);
vNodes[i].setExpanded(true);
SelectNode(vNodes[i]);
}
}

是点击全选按钮,然后把树形结构的所有节点全选!但树形结构的数据量太大,点击后会造成IE假死…等它运行完成已经是十几分钟之后的事了。
现在就是想请求一下各位高手,能不能优化这两个方法!
展开
 我来答
sanshizi
2009-06-25 · TA获得超过448个赞
知道小有建树答主
回答量:364
采纳率:0%
帮助的人:326万
展开全部
对树操作时间大,那就换个思路嘛,直接处理html元件就快了,
既然能全选,那必然用了checkbox

假设你的checkbox都是放在一个id为"mytree"的div里,

给你我在用的js:
function checkAll(x):是所有id中包含x变量的input,你可以继续添加其他条件
var objs = document.getElementsByTagName("input");
这句可以改成document.getElementById("mytree").getElementsByTagName("input");
只操作树中的input速度会更快些

<script>
function checkAll(x){
var objs = document.getElementsByTagName("input");
for(var i=0; i<objs.length; i++){
if(objs[i].type.toLowerCase() == "checkbox" )
if(objs[i].name.toLowerCase().indexOf(x) >-1){
objs[i].checked = true;
}
}
}
</script>
Foxcoming
2009-06-25 · TA获得超过692个赞
知道小有建树答主
回答量:718
采纳率:0%
帮助的人:821万
展开全部
试一下ResumeLayout。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式