[原创]递归读取DataTable加载TreeList控件


[原创]递归读取DataTable加载TreeList控件


如遇到特殊情况不能直接绑定DataSource属性加载树,此时我们只能通过编程方式加载了。下面分享一个类:
RecusiveCreateTreeList ,通过递归读取DataTable加载TreeList控件,只需写少量代码就能完成数据展示。

贴图图片

最重要是表结构定义,isid和ParentID组成父子结点关系。

贴图图片

RecusiveCreateTreeList类应用,用法很简单的:


//如转帖请注明出处,by www.csframework.com
 private void btnRecusiveCreate_Click(object sender, EventArgs e)

        {

            //获取树数据

            DataTable dt = DataProvider.Instance.GetTable("select * from [tb_department]", "tb_department");

 

            //实例化一个加载器,用于创建树

            RecusiveCreateTreeList creator = new RecusiveCreateTreeList(treeList1, dt,this.DataRow2NodeHandler);

 

            //调用CreateTree方法

            creator.CreateTree("isid", "ParentID", "0");

 

            treeList1.ExpandAll();

        }

 


实现DataRow转换为TreeListNode的方法。


  private TreeListNode DataRow2NodeHandler(DataRow row, TreeList tree, TreeListNode parentNode)

        {

            TreeListNode node = tree.AppendNode(new object[]
              { row[
"DeptCode"], row["DeptName"], row["TagValue"] },
parentNode);

            return node;

        }


DataRow转换为TreeListNode委托定义

 public delegate TreeListNode DataRow2NodeHandler(DataRow row, TreeList tree, TreeListNode parentNode);



通用TreeList树加载器

public
class RecusiveCreateTreeList
{
   private TreeList _tree;
   private DataTable _data;
   private DataRow2NodeHandler _handle;
   
   public RecusiveCreateTreeList(TreeList tree, DataTable data, DataRow2NodeHandler handle)
   {
      _data = data;
      _tree = tree;
      _handle = handle;
   }
   
   private DataRow[] GetRows(string parentFieldName, string parentValue)
   {
      string filter = string.Format("{0}={1}", parentFieldName, parentValue);
      return _data.Select(filter);
   }
   
   private bool HasSubRows(string parentFieldName, string parentValue)
   {
      return this.GetRows(parentFieldName, parentValue).Length > 0;
   }
   
   /// <summary>
   /// 生成一级菜单的树结构.
   /// </summary>
   public void CreateTree(string keyFieldName, string parentFieldName, string rootValue)
   {
      
      this._tree.Nodes.Clear();
      this._tree.BeginUpdate();
      
      //根结点记录
      DataRow[] rows = this.GetRows(parentFieldName, rootValue);
      DataRow[] childs;
      
      string pValue;//parentValue;
      string kValue;//key value
      TreeListNode root;
      
      foreach (DataRow row in rows)
      {
         pValue = row[parentFieldName].ToString();
         kValue = row[keyFieldName].ToString();
         
         root = _handle(row, _tree, null);
         
         childs = this.GetRows(parentFieldName, kValue);
         if (childs.Length > 0)
         CreateChild(childs, root, keyFieldName, parentFieldName);
      }
      this._tree.EndUpdate();
   }
   
   /// <summary>
   /// 生成子菜单的树结构
   /// </summary>
   private void CreateChild(DataRow[] childs, TreeListNode parentNode,
   string keyFieldName, string parentFieldName)
   {
      string pValue;//parentValue;
      string kValue;//key value
      TreeListNode root;
      
      foreach (DataRow row in childs)
      {
         pValue = row[parentFieldName].ToString();
         kValue = row[keyFieldName].ToString();
         
         root = _handle(row, _tree, parentNode);
         
         childs = this.GetRows(parentFieldName, kValue);
         if (childs.Length > 0)
         CreateChild(childs, root, keyFieldName, parentFieldName);
      }
   }
}



Source code:

版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
C/S框架网
上一篇:C#积木游戏(改编自DevExpress GridTetris)
下一篇:C#绑定TreeList的DataSource属性及获取DataRow数据
评论列表

发表评论

评论内容
昵称:
关联文章

[]读取DataTableTreeList
】C# 深度拷贝对象 使用.NET反射+原理实现深度克隆
使用获取TreeList中所有勾选的结点
DevExpress TreeList 自动数据源并显示漂亮图标
Winform布局开源框架,Winform框架,插化框架|C/S框架网
Winform 快速初始化Dev TreeList的数据
VS2017工具箱无法DevExpress15.2.x(添加选项卡DLL解决)
[]超牛Outlook导航导(Outlook Navigation Panel)
】C# Winform Dev自动下拉弹框筛选数据PopupContainerEdit组
[]无线监控系统之二-------C#实现(续)
C#读取XML文件
VS工具栏手工DevExpress组
DevTreeListView.SetImageIndex 设置TreeList显示的图标
ucWindowTitle用户 - 用户界面规范
JS日期
SQL获取当前类别及所有子类别,用于按类型查询
C#获取LINQ列表中所有子级项目
使用Scheduler实现生产进度监控程序
C#.Net自定义 - GridPopupContainerLookup
[]Asp.Net的GridView绑定空数据显示标题

热门标签
.NET5 .NET6 .NET7 APP Auth-软件授权注册系统 Axios B/S B/S开发框架 Bug Bug记录 C#加密解密 C#源码 C/S CHATGPT CMS系统 CodeGenerator CSFramework.DB CSFramework.EF CSFrameworkV1学习版 CSFrameworkV2标准版 CSFrameworkV3高级版 CSFrameworkV4企业版 CSFrameworkV5旗舰版 CSFrameworkV6.0 DAL数据访问层 Database datalock DbFramework Demo教学 Demo下载 DevExpress教程 DOM EF框架 Element-UI EntityFramework ERP ES6 Excel FastReport GIT HR IDatabase IIS JavaScript LINQ MES MiniFramework MIS NavBarControl Node.JS NPM OMS ORM PaaS POS Promise API Redis SAP SEO SQL SQLConnector TMS系统 Token令牌 VS2022 VSCode VUE WCF WebApi WebApi NETCore WebApi框架 WEB开发框架 Windows服务 Winform 开发框架 Winform 开发平台 WinFramework Workflow工作流 Workflow流程引擎 版本区别 报表 踩坑日记 操作手册 代码生成器 迭代开发记录 基础资料窗体 架构设计 角色权限 开发sce 开发技巧 开发教程 开发框架 开发平台 开发指南 客户案例 快速搭站系统 快速开发平台 秘钥 密钥 权限设计 软件报价 软件测试报告 软件简介 软件开发框架 软件开发平台 软件开发文档 软件体系架构 软件下载 软著证书 三层架构 设计模式 生成代码 实用小技巧 收钱音箱 数据锁 数据同步 微信小程序 未解决问题 文档下载 喜鹊ERP 喜鹊软件 系统对接 详细设计说明书 行政区域数据库 需求分析 疑难杂症 蝇量级框架 蝇量框架 用户管理 用户开发手册 用户控件 在线支付 纸箱ERP 智能语音收款机 自定义窗体 自定义组件 自动升级程序