首先事件选择,选择的是MouseUp事件。为啥?因为凡是跟Check有关的,在选中父节点或者子节点,都会二次触发。然后发生的就是死循环。

Up事件就可以避免二次触发。Down事件呢?那就触发AfterCheck事件了。事件选好了, 直接上代码。

处理思路:选中/取消当前节点,先选中其所有父节点,再选中其子节点

注意平级节点处理:有平级节点选中,取消时需要遍历父节点。

若有一个平级节点处于选中,则父节点为选中。

若所有平级都没有选中的了,则父节点要取消选中

        /// <summary>
/// 处理树节点选中和取消选中
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
public static void treeView_MouseUpClick(object sender,MouseEventArgs e)
{
TreeView tree = sender as TreeView;
if (tree == null)
return;
TreeNode node = tree.GetNodeAt(e.X, e.Y);
if (node == null)
return;
SetTreeNodeCheckBoxState(node,true,node.Checked);
SetTreeNodeCheckBoxState(node, false, node.Checked);
} /// <summary>
/// 处理父节点,子节点的选中
/// </summary>
/// <param name="node">需要选中的树</param>
/// <param name="isSetParentState">是否选中父节点</param>
/// <param name="state">选中/不选中</param>
public static void SetTreeNodeCheckBoxState(TreeNode node, bool isSetParentState, bool state)
{
if (node == null)
return;
node.Checked = state;
if (isSetParentState && node.Parent != null && node.Checked==true)
{
SetTreeNodeCheckBoxState(node.Parent, isSetParentState, state);
}
else if (isSetParentState && node.Parent != null && node.Checked == false)
{
//处理取消选中
bool isSelect = false;
foreach(TreeNode n in node.Parent.Nodes)
{
if (n.Checked==true)
isSelect = true;
}
//平级都未有选中的才取消选中
if(isSelect==false)
SetTreeNodeCheckBoxState(node.Parent, isSetParentState, state);
}
else if (!isSetParentState && node.Nodes!=null && node.Nodes.Count > )
{
foreach (TreeNode node2 in node.Nodes)
{
SetTreeNodeCheckBoxState(node2, isSetParentState, state);
}
}
}

TreeView树,全选,反选,平级选操作的更多相关文章

  1. jQuery实现checkbox全选反选及删除等操作

    1.list.html 说明:用checkbox数组Check[]存放每一行的ID值 <div id="con"> <table width="100% ...

  2. jQuery之标签操作和返回顶部、登录验证、全选反选、克隆示例

    一.样式操作 1.JQ中的样式类 somenode.addClass();// 添加指定的CSS类名. somenode.removeClass();// 移除指定的CSS类名. somenode.h ...

  3. html中全选反选

    <!--第一层--> <div class="first"> <div class="first_top"> <img ...

  4. JavaScript、全选反选-课堂笔记

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 关于input全选反选恶心的异常情况

    上一篇讲到:第一次点击全选按钮input显示对勾,第二次则不显示,需要用prop来添加checked属性. 但是用prop会出现一个问题,对勾显示,而checked属性不会被添加(比如:$(" ...

  6. jQuery全选/反选checkbox

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. python: jquery实现全选 反选 取消

    引入这个jquery-1.12.4.js jquery实现全选 反选 取消 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitio ...

  8. BootStrapt iCheck表单美化插件使用方法详解(含参数、事件等) 全选 反选

    特色: 1.在不同浏览器(包括ie6+)和设备上都有相同的表现 — 包括 桌面和移动设备 2.支持触摸设备 — iOS.Android.BlackBerry.Windows Phone等系统 4.方便 ...

  9. jquery 全选 全不选 反选

    1.概述 在项目中经常遇到列表中对复选框进行勾选操作,全选...反选.. 2. example <html> <body> <form id="test-for ...

随机推荐

  1. 将qemu使用的设备树dump出来

    像下面的qemu启动命令: sudo qemu-system-aarch64 \ -M virt \ -cpu cortex-a53 \ -smp \ -m 4096M \ -kernel ./lin ...

  2. ansible自动化运维03

    ansible自动化运维常用模块 常用模块实现的功能:安装软件包:修改配置文件:创建程序用户组:创建目录,并修改所属和权限:挂载:启动服务:测试. command模块: shell模块: 注意:com ...

  3. js日期增加或减少一天

    想自己写一个日期的加减方法,但是涉及到每个月天数的判断,如果是2月份的话,还要涉及到闰年的判断,有些复杂,其实只要调用Date对象的setDate()函数就可以了,具体方法如下: function a ...

  4. 201871020225-牟星源《面向对象程序设计(JAVA)》第二周学习总结

    正文: 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-dai ...

  5. pl/sql的tnsnames.ora文件配置

    位置:D:\app\product\11.2.0\dbhome_1\network\admin\tnsnames.ora(根据安装位置具体情况而定) zx_U=  (DESCRIPTION =    ...

  6. Anaconda3(5-2)程序编辑器 win10下PyCharm安装及配置Pytorch流程

    由于破解和付费问题,不推荐.优先用自带的spyder Win10 下PyCharm安装流程:(1)官网:https://www.jetbrains.com/pycharm/download/#sect ...

  7. Visual Studio调试XSLT

    Visual Studio是一个很大的工具.很容易遗漏一些有用的特性.希望XSLT调试器不会错过.在下面,您可以看到调试器正在运行,因为xslt转换正在应用于某些XML.(请原谅我在示例中使用的毫无意 ...

  8. CPU中断的工作原理,从最底层讲起

    前言 中断的概念属于硬件层.虽然我们在进行软件编程时不会直接使用中断,但理解它对我们来说依然重要. 我们在使用线程切换及状态管理.异常处理.硬件与处理器的交互.I/O操作等指令时,中断都在默默的为我们 ...

  9. [RN] React Native 让 Flatlist 支持 选中多个值,并获取所选择的值

    React Native 让 Flatlist  支持  选中多个值,并获取所选择的值 实现效果如下: 实现代码: import React, {Component} from 'react'; im ...

  10. 这里有一个url=https://www/.baidu.com/s?id=111&name=yourname,写一个函数获取query的参数和值存放在一个对象

    console.log(getJson(url)); function getJson(url){ var obj={}; var arr=url.split("?")[1].sp ...