/// 获取目录管理信息集合
         /// </summary>
         /// <returns></returns>
         public List<CatalogTree> GetCatalogTree()
         {
             List<CatalogTree> list = new List<CatalogTree>();
             var db = DatabaseFactory.CreateDatabase("ELManage");
             string sql = "select KeyId,CatalogName,ParentId,SortCode,IsFolder  from EL_Catalog  where EnableMark=1";
             DbCommand cmd = db.GetSqlStringCommand(sql);
             DataTable dt = db.ExecuteDataTable(cmd);
             ; i < dt.Rows.Count; i++)
             {
                 DataRow dr = dt.Rows[i];
                 CatalogTree model = new CatalogTree();
                 model.keyid = Convert.ToString(dr["KeyId"]);
                 model.catalogname = Convert.ToString(dr["CatalogName"]);
                 model.parentid = Convert.ToString(dr["ParentId"]);
                 if (!Convert.IsDBNull(dr["SortCode"]))
                 {
                     model.sortcode = Convert.ToInt32(dr["SortCode"]);
                 }
                 if (!Convert.IsDBNull(dr["IsFolder"]))
                 {
                     model.isfolder = Convert.ToInt32(dr["IsFolder"]);
                 }
                 list.Add(model);
             }
         //获取根节点
             var mds = list.Where(c => c.parentid == "-").OrderBy(t => t.sortcode).ToList();
             foreach (var item in mds)
             {
           //获取子节点
                 item.children = GetChildrens(list, item);
             }
             return mds;
         }

递归获取子节点:

         /// 获取目录管理信息集合
         /// </summary>
         /// <returns></returns>
         public List<CatalogTree> GetCatalogTree()
         {
             List<CatalogTree> list = new List<CatalogTree>();
             var db = DatabaseFactory.CreateDatabase("ELManage");
             string sql = "select KeyId,CatalogName,ParentId,SortCode,IsFolder,TableName from EL_Catalog  where EnableMark=1";
             DbCommand cmd = db.GetSqlStringCommand(sql);
             DataTable dt = db.ExecuteDataTable(cmd);
             ; i < dt.Rows.Count; i++)
             {
                 DataRow dr = dt.Rows[i];
                 CatalogTree model = new CatalogTree();
                 model.keyid = Convert.ToString(dr["KeyId"]);
                 model.catalogname = Convert.ToString(dr["CatalogName"]);
                 model.parentid = Convert.ToString(dr["ParentId"]);
                 if (!Convert.IsDBNull(dr["SortCode"]))
                 {
                     model.sortcode = Convert.ToInt32(dr["SortCode"]);
                 }
                 if (!Convert.IsDBNull(dr["IsFolder"]))
                 {
                     model.isfolder = Convert.ToInt32(dr["IsFolder"]);
                 }
                 list.Add(model);
             }
         //获取根节点
             var mds = list.Where(c => c.parentid == "-").OrderBy(t => t.sortcode).ToList();
             foreach (var item in mds)
             {
           //获取子节点
                 item.children = GetChildrens(list, item);
             }
             return mds;
         }

C#递归加载目录树的更多相关文章

  1. C# IO操作(五)文件的递归加载

    本篇是一个案例,其核心通过代码展示代码中的递归这个用法,程序的界面如下:

  2. C#:将空间数据加载到树视图控件

    自己 整理了 下 代码 测试了下 还行... #region 操作树视图控件 /// <summary> /// 自定义需要的类型 /// </summary> enum Da ...

  3. WinForm 进程、线程、TreeView递归加载、发送邮件--2016年12月13日

    进程:一个程序就是一个进程,但是也有一个程序需要多个进程来支持的情况 进程要使用的类是:Process它在命名空间:System.Diagnostics; 静态方法Start(); Process.S ...

  4. winform进程、线程、TreeView递归加载

    进程: 一般来说,一个程序就是一个进程,不过也有一个程序需要多个进程支持的情况. 进程所使用的类:Process 所需命名空间:System.Diagnostics; 可以通过进行来开启计算机上现有的 ...

  5. 省市数据递归加载到TreeView

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  6. MVC4加载zTree树小控件

    前言: 第一次学习使用MVC框架,找了个练手项目,加载zTree树小控件.下面我就一步步说明我这次练手的经历以记录.如果有什么错误,希望各位大神帮忙指正,谢谢. 第一步: 利用VS2010新建一个MV ...

  7. 将Xml文件递归加载到TreeView中

    #region [通过XDocument的方式将Xml文件递归到TreeView控件中] //读取Xml文件(XDocument) //1.加载Xml文件 XDocument  document=XD ...

  8. 转:zTree树控件实战篇:针对多个下拉加载zTree树应该如何做出合理的配置

    今天有一个zTree的朋友遇到一个非常棘手的问题,才研究zTree树控件两天就被上头催着看成果,很是苦恼.他面对的问题就是页面内多个地方需要下拉在其文本框下方加载zTree树,由于对zTree下拉加载 ...

  9. python- 动态加载目录下所有的类

    # 背景 自动化测试框架中model层下有很多类,用来操作mysql的,使用的时候需要把全部的类加载进来,需要使用到动态加载类 # 解决方法 使用pkgutil,内置的方法,常用的话有两个方法 ite ...

随机推荐

  1. js中的offsetWidth用法

    offsetWidth  //返回盒模型的宽度(包括width+左右padding+左右border) <style> #div1 { width:200px; height:200px; ...

  2. 【转载】JDK8 特性 stream(),lambda表达式,

    Stream()表达式 虽然大部分情况下stream是容器调用Collection.stream()方法得到的,但stream和collections有以下不同: 无存储.stream不是一种数据结构 ...

  3. ulimit 管理系统资源

    具体的 options 含义以及简单示例可以参考以下表格. 选项 含义 例子 -H 设置硬资源限制,一旦设置不能增加. ulimit – Hs 64:限制硬资源,线程栈大小为 64K. -S 设置软资 ...

  4. Airbnb JavaScript 编码风格指南(2018年最新版)

    原网址 :  https://segmentfault.com/a/1190000013040555 类型 基本类型:直接存取 string number boolean null undefined ...

  5. python面向对象--类和实例的认识

    '''1.数据属性 2.函数属性''' #创建一个类class Chinese: "这是一个中国人的类" #类属性 money=4000 #注意类和对象均用点来访问自己的属性 de ...

  6. error: must use ‘class’ tag to refer to type ‘XXX’ in this scope

    开发环境: Qt Creator 4.8.2 在写程序的时候,遇到了编译器报错 error: must use 'class' tag to refer to type 'XXX' in this s ...

  7. git路径超长 及gitignore

    1 忽略路径超长 git config --system core.longpaths true 2 比较全的gitignore https://www.gitignore.io/api/vim,no ...

  8. group_by

    1.按照一个列或者多个列对数据分组 2.对每个组进行聚合操作 3. 对聚合后的结果进行判断 1. select avg(score) as score from teacher 2. select   ...

  9. phpStorm 配置PHP_CodeSniffer自动检查代码

    环境 ubuntu18.4 phpstorm php7.2 最正确安装方法 sudo apt-get install php-codesniffer 一.composer安装PHP_CodeSniff ...

  10. 关于BFC的总结

    虽然工作这么多年了,但是如果让我直接解释一下什么是BFC的时候,还是感觉有点不知道怎么准确的表达,下面就翻翻文档,总结一下,加深一下认识吧.大家也可以关注我的GitHub后续的更新 1.BFC的基本概 ...