ASP.NET 2.0 TreeView has many built-in features such as showing a checkbox for all the Tree Nodes. Node level formating, style, etc., Enabling the ShowCheckBoxes=”All” property sets it to show a checkbox for all the nodes. The other options are Leaf, None, Parent and Root which show checkboxes at the respective node levels. None doesnt display CheckBoxes. When we set ShowCheckBoxes=”All”, we would like to provide a feature where people can select the checkbox on the Root Node so that all the other checkboxes are checked automatically. Basically, when the parent node is checked, all the child nodes should be checked automatically. It would be intuitive to accomplish this task at the client side without involving a postback. The following code snippet helps in accomplishing the same. TreeView Declaration <asp:TreeView ID=”TreeView1″ Runat=”server” DataSourceID=”XmlDataSource1″ onclick=”client_OnTreeNodeChecked();” ShowCheckBoxes=”all”> <DataBindings> <asp:TreeNodeBinding DataMember=”Category” ValueField=”ID” TextField=”Name”></asp:TreeNodeBinding> <asp:TreeNodeBinding DataMember=”Description” ValueField=”Value” TextField=”Value”></asp:TreeNodeBinding> </DataBindings> </asp:TreeView> The Javascript Code snippet is as follows:- <script language=”javascript” type=”text/javascript”>
In the above TreeView declaration Code, you can find the property onclick=”client_OnTreeNodeChecked();” event which actually is the JavaScript function which would accomplish this task.
function client_OnTreeNodeChecked()
{
var obj = window.event.srcElement;
var treeNodeFound = false;
var checkedState;
if (obj.tagName == “INPUT” && obj.type == “checkbox”) {
var treeNode = obj;
checkedState = treeNode.checked;
do
{
obj = obj.parentElement;
} while (obj.tagName != “TABLE”)
var parentTreeLevel = obj.rows[0].cells.length;
var parentTreeNode = obj.rows[0].cells[0];
var tables = obj.parentElement.getElementsByTagName(“TABLE”);
var numTables = tables.length
if (numTables >= 1)
{
for (i=0; i < numTables; i++)
{
if (tables[i] == obj)
{
treeNodeFound = true;
i++;
if (i == numTables)
{
return;
}
}
if (treeNodeFound == true)
{
var childTreeLevel = tables[i].rows[0].cells.length;
if (childTreeLevel > parentTreeLevel)
{
var cell = tables[i].rows[0].cells[childTreeLevel – 1];
var inputs = cell.getElementsByTagName(“INPUT”);
inputs[0].checked = checkedState;
}
else
{
return;
}
}
}
}
}
}
</script>
asp.net 2.0 treeview checkboxes – check all – javascript _asp.net技巧
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » asp.net 2.0 treeview checkboxes – check all – javascript _asp.net技巧
相关推荐
-      对.net framework 反射的反思_asp.net技巧
-      .net3.5和vs2008中的asp.net ajax_asp.net技巧
-      使用asp.net ajax框架扩展html map控件_asp.net技巧
-      asp.net应用程序资源访问安全模型_asp.net技巧
-      photoshop初学者轻松绘制螺旋漩涡特效_photoshop教程
-      photoshop通道结合图层模式抠狗尾巴草_photoshop教程
-      web.config详解+asp.net优化_asp.net技巧
-      asp.net中多彩下拉框的实现_asp.net技巧