zoukankan      html  css  js  c++  java
  • asp.net2.0下利用javascript实现treeview中的checkbox全选

    实现了对Treeview控件中选择框CheckBox的全选处理。实现的是菜单选择框父项打勾后它下面的子项选择框全部为打勾。如果其中一项子 项取消打勾父项父项选择框为空。主要效果见下图:

    主要的实现原理是在TreeView控件的onclick事件中用JS实现全选操作。
    <script language="javascript"  type="text/javascript">    
       function OnTreeNodeChecked() 
       

        var ele 
    = event.srcElement; 
        
    if(ele.type=='checkbox'
        

            var childrenDivID 
    = ele.id.replace('CheckBox','Nodes');
            var div 
    = document.getElementById(childrenDivID); 
            
    if(div != null)
            
    {
                var checkBoxs 
    = div.getElementsByTagName('INPUT'); 
                
    for(var i=0;i<checkBoxs.length;i++
                

                    
    if(checkBoxs[i].type=='checkbox'
                    checkBoxs[i].
    checked=ele.checked
                }

            }

            
    else
            
    {
                var div 
    = GetParentByTagName(ele,'DIV');
                var checkBoxs 
    = div.getElementsByTagName('INPUT'); 
                var parentCheckBoxID 
    = div.id.replace('Nodes','CheckBox');
                var parentCheckBox 
    = document.getElementById(parentCheckBoxID);
                
    for(var i=0;i<checkBoxs.length;i++
                
    {
                    
    if(checkBoxs[i].type=='checkbox' && checkBoxs[i].checked)
                    
    {
                        parentCheckBox.
    checked = true;
                        
    return;
                    }

                }

                parentCheckBox.
    checked = false;
            }

            
        }
     
    }


              function GetParentByTagName(element, tagName)
              
    {
                var parent 
    = element.parentNode;
                var upperTagName 
    = tagName.toUpperCase();
                
    while (parent && (parent.tagName.toUpperCase() != upperTagName)) 
                
    {
                  parent 
    = parent.parentNode ? parent.parentNode : parent.parentElement;
                }

                 
    return parent;
              }

              
        
    </script>

    剩下的就是TreeView控件绑定的onclick事件了。
    <asp:TreeView ID="TreeView1" runat="server" onclick="OnTreeNodeChecked()" ShowCheckBoxes="All"   ExpandDepth="2" Width="100%" Height="100%">
                                       
    </asp:TreeView>
    至此实现了所有的用JS实现TreeView控件的全选与部分选择的问题。
  • 相关阅读:
    C# vb实现浮雕特效滤镜效果
    一张图看懂SharpImage
    C#控制操控操作多个UVC摄像头设备
    C#读写修改设置调整UVC摄像头画面-缩放
    继承多态绕点 Java篇
    继承多态绕点 C#篇
    lock关键字理解
    关于C#迭代器
    关于排列组合中组合结果
    C#与Java中相等关系
  • 原文地址:https://www.cnblogs.com/huangwen/p/718573.html
Copyright © 2011-2022 走看看