最近做项目新增光纤线路清查功能模块,思路和算法已经想好了,些代码时候居然在一个控件上纠结了好长的时间,虽然后来搞定了,但是好记性不然烂笔头,还是写下来,以后要用到的时候直接翻就行,帮助文档看得比较纠结,还是自己写的好。往往当时会用了,一段时间没用后再用的时候有要翻帮助文档或网上搜,纠结很久。我们学东西的时候一般不应该花过多精力和时间到控件或框架上,但是做项目要的是结果。记得有次去面试败在机试上,题也简单,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"是一个实例项目,旨在帮助开发者理解和掌握TreeList控件的基本用法和高级特性。通过提供的DevExpressTreeListDemo.sln解决方案文件和DevExpressTreeListDemo项目,我们可以深入...
DevExpress TreeList 是一款强大的数据控件,常用于展示层次结构的数据。在开发Windows Forms或ASP.NET应用程序时,它提供了一种高效且用户友好的方式来显示和操作树形结构的数据。本文将深入探讨如何实现DevExpress...
.NET框架提供了多种数据绑定机制,如DataSource属性、BindingSource组件等,这些机制可以方便地与DevExpress TreeList结合使用,确保数据和UI的一致性。 通过上述介绍,我们可以看到DevExpress TreeList在处理复杂...
在.NET开发环境中,DevExpress TreeList控件是一种常用的用于展示数据的树形结构组件,尤其在Windows Forms应用程序中。本文将详细讲解如何从JSON格式的数据读取并转换为DevExpress TreeList的树形结构,以实现数据...
本文将对 DevExpress Treelist 控件的使用实例进行详细的介绍,包括如何创建 Treelist 控件、添加右击菜单、绑定数据源等。 一、创建 Treelist 控件 在使用 Treelist 控件之前,需要首先创建一个 Treelist 实例。...
这个子文件可能包含一系列教程或代码示例,涵盖了更高级或特定的TreeList用法,比如如何实现复杂的数据绑定、自定义编辑模板、实现拖放操作、使用内置的过滤和排序功能,或者与其他DevExpress控件集成等。...
DevExpress TreeList是DevExpress组件库中的一个功能强大的树形列表控件,它广泛应用于需要以树形结构显示数据的Windows窗体应用程序中。由于其功能丰富和复杂性,开发者在使用过程中可能会遇到一些常见的问题。以下...
DevExpress TreeList 是一款强大的数据控件,用于在Windows Forms应用程序中展示树形结构的数据。在开发过程中,有时我们需要自定义控件的外观,比如改变图片节点的背景色以突出显示某些信息或根据业务规则进行视觉...
至此,你已经掌握了如何使用C#和DevExpress TreeList控件在Winforn应用程序中显示指定路径下的所有目录和文件。你可以根据实际需求进行调整,比如添加更多列来显示其他信息,或者添加搜索、筛选等功能。务必确保处理...
这个压缩包"Winform中DevExpress的TreeList的入门使用示例代码.zip"包含了一个简单的使用DevExpress TreeList控件的示例,帮助开发者快速理解和应用。 TreeList控件的主要特点和功能包括: 1. **多列布局**:...
在这个特定的案例中,我们关注的是"Dev Treelist"和"GridControl",这两个组件是DevExpress工具包中的核心部分,常用于数据展示和管理。 **Dev Treelist** 是一个树形视图控件,它能够以层次结构的方式展示数据。在...
本文将深入探讨如何在DevExpress环境中使用TreeList控件,并结合SearchControl进行节点查询。 1. **微软TreeView控件的实现与思考** - TreeView控件是Windows Forms开发中常见的用于展示层次数据的控件。开发者...
在.NET开发中,DevExpress是一款广泛使用的控件库,其中的TreeList控件是用于构建层级数据展示的强大工具。本文将详细解析如何利用DevExpress的TreeList控件实现向上递归获取符合条件的父节点这一功能。 首先,我们...
DevExpress TreeList 是一款强大的数据控件,常用于展示层次结构的数据。在某些情况下,我们可能希望根据特定条件来隐藏或显示树形列表中的节点的复选框(CheckBox)。本篇文章将详细阐述如何利用DevExpress提供的...
本文将详细介绍如何在C#中使用DevExpress TreeList控件实现向上递归获取公共父节点的方法。 首先,我们需要理解递归的概念。递归是一种编程技巧,函数调用自身来解决问题。在上下文中,递归用于遍历TreeList的层级...
节点折叠 this.treeList1.CollapseAll(); 一、简介 二、属性列表 1、OptionsSelection: EnableAppearanceForcusedCell:选中的Cell的Appearance设置是否可用。默认为True; EnableAppearanceForcusedRow:...