日期:2014-05-19  浏览次数:20449 次

TreeView使用CheckBox的问题
请问高手
1:如何实现在点击TreeView的父节点的CheckBox后,实现其全部子节点的CheckBox的值跟父节点的一致,而在点击某个子节点的CheckBox后,父节点的值也和子节点一致

TreeView有没有象checkboxlist那样的autopostback的回传属性?
2.能不能让TreeView的那些节点只能实现CheckBox选择,而不能实现点击,也就是让它只实现显示而不能实现跳转功能。
在线急等。。
我用C#.net2005   哦

------解决方案--------------------
<script type= "text/javascript ">

function public_GetParentByTagName(element, tagName)
{
var parent = element.parentNode;
var upperTagName = tagName.toUpperCase();
//如果这个元素还不是想要的tag就继续上溯
while (parent && (parent.tagName.toUpperCase() != upperTagName))
{
parent = parent.parentNode ? parent.parentNode : parent.parentElement;
}
return parent;
}

//设置节点的父节点Cheched——该节点可访问,则他的父节点也必能访问
function setParentChecked(objNode)
{
var objParentDiv = public_GetParentByTagName(objNode, "div ");
if(objParentDiv==null || objParentDiv == "undefined ")
{
return;
}
var objID = objParentDiv.getAttribute( "ID ");
objID = objID.substring(0,objID.indexOf( "Nodes "));
objID = objID+ "CheckBox ";
var objParentCheckBox = document.getElementById(objID);
if(objParentCheckBox==null || objParentCheckBox == "undefined ")
{
return;
}
if(objParentCheckBox.tagName!= "INPUT " && objParentCheckBox.type == "checkbox ")
return;
objParentCheckBox.checked = true;
setParentChecked(objParentCheckBox);
}

//设置节点的子节点uncheched——该节点不可访问,则他的子节点也不能访问
function setChildUnChecked(divID)
{
var objchild = divID.children;
var count = objchild.length;
for(var i=0;i <objchild.length;i++)
{
var tempObj = objchild[i];
if(tempObj.tagName== "INPUT " && tempObj.type == "checkbox ")
{
tempObj.checked = false;
}
setChildUnChecked(tempObj);
}
}

//设置节点的子节点cheched——该节点可以访问,则他的子节点也都能访问
function setChildChecked(divID)
{
var objchild = divID.children;
var count = objchild.length;
for(var i=0;i <objchild.length;i++)
{
var tempObj = objchild[i];
if(tempObj.tagName== "INPUT " && tempObj.type == "checkbox ")
{
tempObj.checked = true;
}
setChildChecked(tempObj);
}
}

//触发事件
function CheckEvent()
{

var objNode = event.srcElement;

if(objNode.tagName!= "INPUT " || objNode.type!= "checkbox ")
return;

if(objNode.checked==true)
{
setParentChecked(objNode);
var objID = objNode.getAttribute( "ID ");
var objID = objID.substring(0,objID.indexOf( "CheckBox "));
var objParentDiv = document.getElementById(objID+ "Nodes ");
if(objParentDiv==null || objParentDiv == "undefined ")
{
return;
}
setChildChecked(objParentDiv);
}
else
{
var objID = objNode.getAttribute( "ID ");
var objID = objID.substring(0,objID.indexOf( "CheckBox "));
var objParentDiv = document.getElementById(objID+ "Nodes ");
if(objParentDiv==null || objParent