博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DevExpress TreeList控件的复选框
阅读量:6975 次
发布时间:2019-06-27

本文共 2897 字,大约阅读时间需要 9 分钟。

        作者:jiankunking 出处:

        TreeList控件能够同一时候显示树结构和其它数据列,即在一个列上建立父子关系展开或收缩,同一时候还能够显示其它列的内容。

        在TreeList中同一时候引入了 Node和 Columns概念, 第一列为树结构, 其余列为数据列, 不论什么列都可作为树结构列(即拖动到第一列)显示。
实现多级树---数据源绑定
        在TreeList里加入要显示列(第一列为树结构。其它列为数据列),并指定FieldName为数据库列名
        指定KeyFieldName属性为主键。ParentFieldName属性为树状分组列。注意 ParentFieldName指定的列假设为空值,树状可能会混乱(仅仅有一个根结点,其它为此节点的子结点)
        用TreeList.DataSource = DataTable 绑定数据就可以
树形控件是使用频率非常高的一种控件。对于属性控件往往须要以下两个功能:
        1.TreeList带有CheckBox,而且节点要有三种状态(所有的子节点都选中,所有的子节点都没选择,一部分子节点选中)。

使用DevXpress的TreeList控件非常easy实现这一功能。

        设置TreeList.OptionsView.ShowCheckBoxes = true //是否显示CheckBox
        设置TreeList.OptionsBehavior.AllowIndeterminateCheckState = true; //设置节点是否有中间状态,即一部分子节点选中,一部分子节点没有选中
设置这两个属性之后就实现了TreeList带有CheckBox,而且节点有三种状态。

        2.选中父节点或者子节点相互影响的功能,如选择父节点选择所有子节点。绑定TreeList的两个事件AfterCheckNode和BeforeCheckNode
DevExpress的TreeList要想在节点前面显示复选框,得改动属性OptionsView->ShowCheckBoxes=True
复选框的子节点与父节点统一的规则有:
        1、选择某一节点时,该节点的子节点所有选择
        2、取消某一节点时,该节点的子节点所有取消选择
        3、某节点的子节点所有选择时,该节点选择
        4、某节点的子节点未所有选择时,该节点不选择

#region 节点选中前事件        private void treeList1_BeforeCheckNode(object sender, DevExpress.XtraTreeList.CheckNodeEventArgs e)        {            if (e.PrevState == CheckState.Checked)            {                e.State = CheckState.Unchecked;            }            else            {                e.State = CheckState.Checked;            }        }        #endregion        #region 节点选中后事件        private void treeList1_AfterCheckNode(object sender, DevExpress.XtraTreeList.NodeEventArgs e)        {            SetCheckedChildNodes(e.Node, e.Node.CheckState);            SetCheckedParentNodes(e.Node, e.Node.CheckState);        }        #endregion        #region 设置子节点状态        private void SetCheckedChildNodes(DevExpress.XtraTreeList.Nodes.TreeListNode node, CheckState check)        {            for (int i = 0; i < node.Nodes.Count; i++)            {                node.Nodes[i].CheckState = check;                SetCheckedChildNodes(node.Nodes[i], check);            }        }        #endregion        #region 设置父节点状态        private void SetCheckedParentNodes(DevExpress.XtraTreeList.Nodes.TreeListNode node, CheckState check)        {            if (node.ParentNode != null)            {                bool b = false;                CheckState state;                for (int i = 0; i < node.ParentNode.Nodes.Count; i++)                {                    state = (CheckState)node.ParentNode.Nodes[i].CheckState;                    if (!check.Equals(state))                    {                        b = !b;                        break;                    }                }                if (b)                {                    node.ParentNode.CheckState = CheckState.Indeterminate;                }                else                {                    node.ParentNode.CheckState = check;                }                SetCheckedParentNodes(node.ParentNode, check);            }        }        #endregion

转载地址:http://utesl.baihongyu.com/

你可能感兴趣的文章
PAT A1078
查看>>
少走弯路,给Java 1~5 年程序员的建议
查看>>
event_loop中不同异步操作的执行顺序
查看>>
纯链式golang http请求库, 支持HTTP代理
查看>>
类的扩充 js中面向对象的技术
查看>>
css 3D动画
查看>>
一名3年工作经验的java程序员应该具备的职业技能
查看>>
基于CRA,使用Redux、Router、Sass等快速搭建纯前端React项目
查看>>
机器喵之红黑树(一)
查看>>
Saltstack 安装配置详解
查看>>
【Tomcat】IDEA下跟踪查看源码
查看>>
Java多线程进阶(三)—— J.U.C之locks框架:ReentrantLock
查看>>
Echarts-百度地图省分着色
查看>>
你不知道的JavaScript :值
查看>>
基于gokit的微服务项目骨架ko
查看>>
Makefile简介
查看>>
《前端竹节》(2)【正则表达式】
查看>>
ECMAScript 6 学习之路 ( 一 )
查看>>
完全使用 Docker 开发 PHP 项目 (三): 命令容器化
查看>>
android综合资讯App、自定义悬浮框、屏幕助手、空灵音乐源码等
查看>>