`
peizhiinfo
  • 浏览: 1439341 次
文章分类
社区版块
存档分类
最新评论

DevExpress TreeList使用心得

 
阅读更多

最近做项目新增光纤线路清查功能模块,思路和算法已经想好了,些代码时候居然在一个控件上纠结了好长的时间,虽然后来搞定了,但是好记性不然烂笔头,还是写下来,以后要用到的时候直接翻就行,帮助文档看得比较纠结,还是自己写的好。往往当时会用了,一段时间没用后再用的时候有要翻帮助文档或网上搜,纠结很久。我们学东西的时候一般不应该花过多精力和时间到控件或框架上,但是做项目要的是结果。记得有次去面试败在机试上,题也简单,CRUD而已,就是不会用控件,浪费了很多时间。

1.数据绑定最基本的两个属性:KeyFieldName和ParentFieldName。

SELECT OfficeID,OfficeName,ParentOfficeID FROM tOffice

这种数据库设计是比较常见的,一般数据满足树形关系就可以这样设计。绑定数据时,只需指定DataSource为对应 的DataTable,指定KeyFieldName为表主键字段,ParentFieldName为表指向主键的外键字段名。

private void BindData() { this.tlOffice.DataSource = dtOffice; tlOffice.KeyFieldName = "OfficeID"; //tlOffice.DataMember = "OfficeName"; tlOffice.Columns["OfficeName"].Caption = "局名称"; tlOffice.ParentFieldName = "ParentOfficeID"; }

绑定数据如下:

为让数据不可编辑,需将OPtionsBehavior→Editable属性设为False:

① . 选择某一节点时,该节点的子节点全部选择 取消某一节点时,该节点的子节点全部取消选择

哪个节点引起行为的?节点是选中还是取消选中?由此确定方法的两个参数:TreeListNode和CheckState。遍历该节点及其子孙,并将其选中状态设置为该节点的状态即可。

/// <summary> /// 选择某一节点时,该节点的子节点全部选择 取消某一节点时,该节点的子节点全部取消选择 /// </summary> /// <param name="node"></param> /// <param name="state"></param> private void SetCheckedChildNodes(TreeListNode node, CheckState check) { for (int i = 0; i < node.Nodes.Count; i++) { node.Nodes[i].CheckState = check; SetCheckedChildNodes(node.Nodes[i], check); } }

② . ,某节点的子节点全部选择时,该节点选择;某节点的子节点未全部选择时,该节点不选择

/// <summary> /// 某节点的子节点全部选择时,该节点选择 某节点的子节点未全部选择时,该节点不选择 /// </summary> /// <param name="node"></param> /// <param name="check"></param> private void SetCheckedParentNodes(TreeListNode node, CheckState check) { if (node.ParentNode != null) { CheckState parentCheckState = node.ParentNode.CheckState; CheckState nodeCheckState; for (int i = 0; i < node.ParentNode.Nodes.Count; i++) { nodeCheckState = (CheckState)node.ParentNode.Nodes[i].CheckState; if (!check.Equals(nodeCheckState))//只要任意一个与其选中状态不一样即父节点状态不全选 { parentCheckState = CheckState.Unchecked; break; } parentCheckState = check;//否则(该节点的兄弟节点选中状态都相同),则父节点选中状态为该节点的选中状态 } node.ParentNode.CheckState = parentCheckState; SetCheckedParentNodes(node.ParentNode, check);//遍历上级节点 } }

上两步写好了,别忘了上面的两个方法在TreeList_AfterCheckNode里面触发:

private void tlOffice_AfterCheckNode(object sender, DevExpress.XtraTreeList.NodeEventArgs e) { SetCheckedChildNodes(e.Node, e.Node.CheckState); SetCheckedParentNodes(e.Node, e.Node.CheckState); }

运行效果如下图:

3.获取选中的复选框数据列表

当用户选择一个或多个节点时,要获取对应的数据,将数据表对应主键存到集合中即可。关键是怎样获取数据,当时就纠结了很久。

private List<int> lstCheckedOfficeID = new List<int>();//选择局ID集合 /// <summary> /// 获取选择状态的数据主键ID集合 /// </summary> /// <param name="parentNode">父级节点</param> private void GetCheckedOfficeID(TreeListNode parentNode) { if (parentNode.Nodes.Count == 0) { return;//递归终止 } foreach (TreeListNode node in parentNode.Nodes) { if (node.CheckState == CheckState.Checked) { DataRowView drv = tlOffice.GetDataRecordByNode(node) as DataRowView;//关键代码,就是不知道是这样获取数据而纠结了很久(鬼知道可以转换为DataRowView啊) if (drv != null) { int OfficeID = (int)drv["OfficeID"]; lstCheckedOfficeID.Add(OfficeID); } } GetCheckedOfficeID(node); } }

下面测试获取主键列表:

private void btnCheck_Click(object sender, EventArgs e) { this.lstCheckedOfficeID.Clear(); if (tlOffice.Nodes.Count > 0) { foreach (TreeListNode root in tlOffice.Nodes) { GetCheckedOfficeID(root); } } string idStr = string.Empty; foreach (int id in lstCheckedOfficeID) { idStr += id + " "; } MessageBox.Show(idStr); }

如下图:

获取选中主键集合后就能处理相关业务了。暂时写到这里了,以后有时间在多多总结。

分享到:
评论

相关推荐

    DevExpress TreeList 使用Demo

    这个"DevExpress TreeList 使用Demo"是一个实例项目,旨在帮助开发者理解和掌握TreeList控件的基本用法和高级特性。通过提供的DevExpressTreeListDemo.sln解决方案文件和DevExpressTreeListDemo项目,我们可以深入...

    DevExpress TreeList 数据绑定

    DevExpress TreeList 是一款强大的数据控件,常用于展示层次结构的数据。在开发Windows Forms或ASP.NET应用程序时,它提供了一种高效且用户友好的方式来显示和操作树形结构的数据。本文将深入探讨如何实现DevExpress...

    DevExpress之TreeList使用示例

    .NET框架提供了多种数据绑定机制,如DataSource属性、BindingSource组件等,这些机制可以方便地与DevExpress TreeList结合使用,确保数据和UI的一致性。 通过上述介绍,我们可以看到DevExpress TreeList在处理复杂...

    读取JSON格式转为DevExpress TreeList 树形(晨曦CZB)

    在.NET开发环境中,DevExpress TreeList控件是一种常用的用于展示数据的树形结构组件,尤其在Windows Forms应用程序中。本文将详细讲解如何从JSON格式的数据读取并转换为DevExpress TreeList的树形结构,以实现数据...

    DevExpress TreeList Demo

    这个子文件可能包含一系列教程或代码示例,涵盖了更高级或特定的TreeList用法,比如如何实现复杂的数据绑定、自定义编辑模板、实现拖放操作、使用内置的过滤和排序功能,或者与其他DevExpress控件集成等。...

    DevExpress设置TreeList图片节点背景色的方法

    DevExpress TreeList 是一款强大的数据控件,用于在Windows Forms应用程序中展示树形结构的数据。在开发过程中,有时我们需要自定义控件的外观,比如改变图片节点的背景色以突出显示某些信息或根据业务规则进行视觉...

    DevExpress TreeList 常见问题解决方法

    主要介绍了DevExpress TreeList 常见问题解决方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

    Winform中DevExpress的TreeList的入门使用示例代码.zip

    这个压缩包"Winform中DevExpress的TreeList的入门使用示例代码.zip"包含了一个简单的使用DevExpress TreeList控件的示例,帮助开发者快速理解和应用。 TreeList控件的主要特点和功能包括: 1. **多列布局**:...

    用Dev Treelist 和 GridControl实现文件资料管理(包括treelist和gridControl使用方法)

    在这个特定的案例中,我们关注的是"Dev Treelist"和"GridControl",这两个组件是DevExpress工具包中的核心部分,常用于数据展示和管理。 **Dev Treelist** 是一个树形视图控件,它能够以层次结构的方式展示数据。在...

    详解在DevExpress程序中使用TreeList控件以及节点查询的处理

    在一般Winform开发的情况下,可以使用微软的TreeView控件,也可以使用DevExpress的TreeList控件进行数据的展示,本篇随笔主要介绍基于DevExpress的TreeList控件使用以及使用SearchControl对节点进行查询的操作。...

    Winforn中DevExpress的TreeList中显示某路径下的所有目录和文件示例代码.zip

    至此,你已经掌握了如何使用C#和DevExpress TreeList控件在Winforn应用程序中显示指定路径下的所有目录和文件。你可以根据实际需求进行调整,比如添加更多列来显示其他信息,或者添加搜索、筛选等功能。务必确保处理...

    DevExpress实现TreeList向上递归获取公共父节点的方法

    本文将详细介绍如何在C#中使用DevExpress TreeList控件实现向上递归获取公共父节点的方法。 首先,我们需要理解递归的概念。递归是一种编程技巧,函数调用自身来解决问题。在上下文中,递归用于遍历TreeList的层级...

    DevExpress实现TreeList向上递归获取符合条件的父节点

    主要介绍了DevExpress实现TreeList向上递归获取符合条件的父节点,需要的朋友可以参考下

    DevExpress实现TreeList按条件隐藏节点CheckBox的方法

    本文实例讲述了DevExpress实现TreeList按条件隐藏节点CheckBox的方法,在项目开发中有一定的使用价值。具体的实现方法如下: 主要功能代码如下: /// /// 隐藏CheckBox /// 说明 /// 在CustomDrawNodeCheckBox事件...

    Treelist使用实例(添加右击菜单)

    本文将对 DevExpress Treelist 控件的使用实例进行详细的介绍,包括如何创建 Treelist 控件、添加右击菜单、绑定数据源等。 一、创建 Treelist 控件 在使用 Treelist 控件之前,需要首先创建一个 Treelist 实例。...

    Devexpress treelist 简介

    节点折叠 this.treeList1.CollapseAll();  一、简介 二、属性列表 1、OptionsSelection:  EnableAppearanceForcusedCell:选中的Cell的Appearance设置是否可用。默认为True;  EnableAppearanceForcusedRow:...

Global site tag (gtag.js) - Google Analytics