zoukankan      html  css  js  c++  java
  • C#中TreeView的CheckBox的两种级联选择

    一、

    //选择全部子项
    private void CheckAllChildNodes(TreeNode treeNode, bool nodeChecked)
    {
    foreach (TreeNode node in treeNode.Nodes)
    {
    node.Checked = nodeChecked;
    if (node.Nodes.Count > 0)
    {
    this.CheckAllChildNodes(node, nodeChecked);
    }
    }
    }

    private void treeView1_AfterCheck(object sender, TreeViewEventArgs e)
    {
    if (e.Action != TreeViewAction.Unknown)
    { //选中全部子结点
    CheckAllChildNodes(e.Node, e.Node.Checked);

    //保留当前节点及值
    bool bol = e.Node.Checked;
    TreeNode tn = e.Node;
    //循环测试直到父结点为空
    while (tn.Parent != null)
    { int i;//判断兄弟结点中是否存在不一致的值
    for ( i= 0; i <tn.Parent.Nodes.Count; i++)
    {
    if (tn.Parent.Nodes[i].Checked != bol)
    {
    break;
    }
    }
    tn=tn.Parent;
    //如果存在不一致的值或当前选项为取消则所有父结点的值必为取消
    if (bol==false&&i==tn.Nodes.Count)
    {
    tn.Checked = false;
    }
    else
    {
    tn.Checked = true;
    }

    }
    }

    }

    二、

       private void CheckSubNodes(TreeNode checkRoot)
            {
                //遍历所有直接子节点,并调整其Check状态为父节点的状态
                foreach (TreeNode tn in checkRoot.Nodes)
                {
                    //注意这里本身并没有直接递归调用CheckSubNodes,但是由于这个操作导致了其子节点的状态变化,产生了AfterCheck事件。
                    tn.Checked = checkRoot.Checked;
                }
            }

    private void tvDept_AfterCheck(object sender, TreeViewEventArgs e)
            {
                CheckSubNodes(e.Node);

            }

  • 相关阅读:
    Cookie&Session会话跟踪技术
    JS前端数据多条件筛选(商品搜索)
    vue数据传递的特殊实现技巧
    Vue2.x directive自定义指令
    vue 自定义组件使用v-model
    Array.prototype.slice.call(arguments)探究
    webstorm快捷键汇总
    表单添加缩略图及截图js代码
    CSS水平垂直居中的几种方法
    下载页面判断客户端
  • 原文地址:https://www.cnblogs.com/kingangWang/p/2139113.html
Copyright © 2011-2022 走看看