TreeList控件可以同时显示树结构和其他数据列,即在一个列上建立父子关系展开或收缩,同时还可以显示其他列的内容。
在TreeList中同时引入了 Node和 Columns概念, 第一列为树结构, 其余列为数据列, 任何列都可作为树结构列(即拖动到第一列)显示。
实现多级树---数据源绑定
在TreeList里添加要显示列(第一列为树结构,其他列为数据列),并指定FieldName为数据库列名
指定KeyFieldName属性为主键,ParentFieldName属性为树状分组列。注意 ParentFieldName指定的列如果为空值,树状可能会混乱(只有一个根结点,其他为此节点的子结点)
用TreeList.DataSource = DataTable 绑定数据即可
树形控件是使用频率很高的一种控件。对于属性控件往往需要下面两个功能:
1.TreeList带有CheckBox,并且节点要有三种状态(所有的子节点都选中,所有的子节点都没选择,一部分子节点选中)。使用DevXpress的TreeList控件很容易实现这一功能。
设置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
分享到:
相关推荐
DevExpress TreeList 数据绑定,很简单,注意KeyFieldName ParentFieldName两个属性设置
读取JSON格式转为DevExpress TreeList 树形。整个发上来的,可以直接运行
代码演示了TreeList常用设置,里面有详细的注释。
Devexpress的TreeList控件的说明文档PDF格式的英文文档
DevExpress之TreeList使用示例:主要演示了DevExpress深层复杂类型绑定,
dotnetbar, 类似devexpress界面控件, 完美破解dotnetbar, 类似devexpress界面控件, 完美破解
在一般Winform开发的情况下,可以使用微软的TreeView控件,也可以使用DevExpress的TreeList控件进行数据的展示,本篇随笔主要介绍基于DevExpress的TreeList控件使用以及使用SearchControl对节点进行查询的操作。...
DevExpress TreeList Demo: 提供对树形控件的全部操作实例,
DevExpress10.1.6控件集合 DevExpress10.1.6控件集合 DevExpress10.1.6控件集合 DevExpress10.1.6控件集合
DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件。本文档主要介绍DevExpress控件使用的详细说明,通过详细说明基本使用方法和属性说明,可以更加快速的入门。总体来讲,使用...
主要介绍了DevExpress实现禁用TreeListNode CheckBox的方法,在项目开发中有应用价值,需要的朋友可以参考下
devExpress layoutcontrol在设计界面里出现的边框线,看上去显得整整齐齐的,生成项目到了运行界面的时候,边框线就不见了,该demo用于演示如何解决该问题
devexpress表格控件gridcontrol实现纵向标头,在官网中找到一些案例整理给大家分享
winform DevExpress强大控件布局 C# 综合系统 界面非常美观、无需修改即可使用 全部源码和数据库 本人亲自测试过 没有任何问题 大家一起学习
DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件。本文档主要介绍DevExpress控件使用的详细说明,通过详细说明基本使用方法和属性说明,可以更加快速的入门。总体来讲,使用...
该资源提供关于DevExpress Winform 的所有可打印控件的导出excel 的通用方法,解决GridControl自带方法不能导出图片,多表头无法导出等问题,解决PivotGridControl导出时候自动分组的问题,真正做到所见所得的导出...
DevExpress 7.3.5控件集合 ---------------------- DevExpress.Data.v7.3.dll DevExpress.Utils.v7.3.4.dll DevExpress.Utils.v7.3.dll DevExpress.Web.ASPxEditors.v7.3.dll DevExpress.Web.ASPxGridView....
主要介绍了DevExpress TreeList 常见问题解决方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
DevExpress三方控件破解补丁