• 本周学习笔记


    1. asp net2.0 TreeView 客户端按需展开,其实msdn里就有,copy出来看着方便点

    设置节点的PopulateOnDemand="True" SelectAction="Expand"属性
    后台treeView TreeNodePopulate事件:

    protected void TreeView1_TreeNodePopulate(object sender, TreeNodeEventArgs e)
        {
            
    if (e.Node.Value == "9"return;
            TreeNode NewNode 
    = new TreeNode(e.Node.Value, (int.Parse(e.Node.Value)+1).ToString());

            
    // Set the PopulateOnDemand property to true so that the child nodes can be 
            
    // dynamically populated.
            NewNode.PopulateOnDemand = true;

            
    // Set additional properties for the node.
            NewNode.SelectAction = TreeNodeSelectAction.Expand;

            
    // Add the new node to the ChildNodes collection of the parent node.
            e.Node.ChildNodes.Add(NewNode);
        }

     2.  TreeView 客户端全选

    通过js实现的选择母节点check后,所有字节点也选中

      <script language="javascript" type="text/javascript">
    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>


    使用:加入treeView客户端点击事件OnClick
    <asp:TreeView ID="TreeView1" runat="server" OnTreeNodePopulate="TreeView1_TreeNodePopulate"
            ShowCheckBoxes="All" onclick="client_OnTreeNodeChecked();" >

    结合第一条动态按需展开:
    因js遍历时,按需获取的node在展开之前无法遍历到,
    新展开的节点默认都没有选中
    因此需要在动态展开时继承其母节点的选中状态
    修改后台TreeView1_TreeNodePopulate事件
    加入:
    TreeNode NewNode = new TreeNode(e.Node.Value, (int.Parse(e.Node.Value) + 1).ToString());

     if (e.Node.Checked == true) NewNode.Checked = true;   //继承母节点选中状态

  • 相关阅读:
    利用Filter和拦截器,将用户信息动态传入Request方法
    Spring统一返回Json工具类,带分页信息
    ASP.NET MVC4 学习记录
    lightgbm 的简单实践案例
    numpy和pandas 各种比较常见的用法总结
    【数据预处理】如何将某一类别特征的极少数类别归为一类
    十大经典算法之Apriori 算法
    常用函数框架
    【解决方案】django初始化执行python manage.py migrate命令后,除default数据库之外的其他数据库中的表没有创建出来
    【解决方案】M2Crypto不支持python3
  • 原文地址:https://www.cnblogs.com/calmzeal/p/762304.html
Copyright © 2020-2023  润新知