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控件的全选与部分选择的问题。
  • 相关阅读:
    正则表达式匹配整数和小数
    解决任务计划程序未启动任务,因为相同任务的实例正在运行的问题
    ActiveMQ 消息持久化到数据库(Mysql、SQL Server、Oracle、DB2等)
    C# CLR20R3 程序终止的几种解决方案
    彻底消除wine中文乱码,QQ,kugoo等等....
    Fedora如何添加第三方软件源?
    [转]Fedora 下安装NVIDIA显卡驱动(使用后无法进入图形界面)
    向fedora添加rpmfusion源
    [转]Java 8 Optional类深度解析(null处理)
    [转载]深入理解Java 8 Lambda
  • 原文地址:https://www.cnblogs.com/huangwen/p/718573.html
Copyright © 2011-2022 走看看