做权限的时候,主要实现如下功能
1、该节点可以访问,则他的父节点也必能访问;
2、该节点可以访问,则他的子节点也都能访问;
3、该节点不可访问,则他的子节点也不能访问。
使用带CheckBox的数型结构能得到很好的用户体验,可是编程的难度也是有点增加,如果全部有服务端来完成,那点下刷下,肯定不行,只能使用javascript,javascript调试的时候郁闷的很,一个字类,还有郁闷的递归,麻烦
我以前是使用以下该方法

<script language="javascript">


//初始化节点

initchecknode(document.all("tvItemClientID").value,document.all("checked").value)


//初始化选中节点

function initchecknode(tree,tvvalue)



{


var selectedNodes = tvvalue;

var arrayNodes = new Array();


var AllRootNode=new Array();

AllRootNode=document.getElementById(tree).getChildren();


findAndCheckedNodes(AllRootNode,arrayNodes);

}


//根据已选择的节点的字符串初始化选择的节点

function findAndCheckedNodes(NodeArray,nodeDatas)



{


if(parseInt(NodeArray.length)==0)



{

return;


else



{

for(var i=0;i<parseInt(NodeArray.length);i++)



{


cNode=NodeArray[i];

////如果该节点在nodeDatas里则初始化checked = true;


for(var j=0;j<nodeDatas.length;j++)



{

if(nodeDatas[j] == nodeData)



{


break;

}


//如果有子节点,则继续递归

if(parseInt(cNode.getChildren().length)!=0)


}

}


//-->

//oncheck事件





var i;

var node=tree.getTreeNode(tree.clickedNodeIndex);


setcheck(node,Pchecked);

setParent(node,Pchecked);


document.all.checked.value = "";

if (tree.getChildren().length > 0)



{





if (tree.getChildren()[i].getAttribute("Checked"))



{

AddChecked(tree.getChildren()[i]);


FindCheckedFromNode(tree.getChildren()[i]);

}


}

//设置子节点选中


function setcheck(node,Pchecked)



{

var i;


ChildNode=node.getChildren();






return;

}





for(i=0;i<ChildNode.length;i++)



{

var cNode;


cNode.setAttribute("Checked",Pchecked);

//cNode.Checked = Pchecked;





setcheck(cNode,Pchecked);

}


}

}


//设置子节点选中/取消;

//同时需要设置父节点的状态(如果是取消选中的话,仅仅设置本节点及其所有字接点,不涉及父接点)





var parentNode = node.getParent();







var parentNodeFather = parentNode.getParent();


if(parentNodeFather)



{

setParent(parentNode,Pc);


if(Pc)

resizeImage('http://images.wangchao.net.cn/images/upload/images/lsdn/1181594183709.png',&ap