TreeView节点互斥,autopostback=false的方法

问题描述:frameset中的TreeView,里面就四个节点,想打开一个后,关闭其它三个节点。
开始是在TreeView1_Expand里写,倒也能用,可要设置autopostback为true,刷新时很难看,就在网上找资料
相关主题如下:
==================
1. "展开时不提交,改变选择节点时才提交"
2. "使TreeView展开一个节点后自动缩回其他所有的已经展开的节点,就是说同一时间内只有一个展开节点"
3. "TreeView展开无闪烁的解决方法"
4. "TreeView专题讨论"
5. "TreeView JavaScript控制方法研究"
==================
上面有个javascript角本写的不错,可试了半天老是出错。
于是自已写了一个。

 1<script language="JavaScript">   
 2function initTree()   
 3{   
 4var tree = document.all["TreeView1"];   
 5tree.attachEvent("onexpand", SelectedIndexChange); //追加个事件   
 6}   
 7function SelectedIndexChange()   
 8{   
 9var temp = this.TreeView1.clickedNodeIndex;   
10var nodes = new Array();   
11nodes = this.TreeView1.getChildren();   
12for(i=0;i<nodes.length;i++)   
13{   
14if(i!=temp)   
15{   
16if(i<10)   
17nodeIndex = "0"+i;//我这只用到了四个节点的,十个以上的自已试试看吧。   
18this.TreeView1.getTreeNode(nodeIndex).setAttribute('expanded','false');   
19}   
20}   
21}   
22</script>

最后在body里写一个

1<body onload="initTree();">   
2就可以用了。 
3
4当然也可以像"TreeView专题讨论"中把javascript写在page_load里,不过那样就很麻烦了,   
5也很容易出错儿。   
6柏林 05-09-24</body>
Published At
Categories with Web编程
Tagged with
comments powered by Disqus