C# 把带有父子关系的数据转化为------树形结构的数据 ,以及 找出父子级关系的数据中里面的根数据Id
紧接上一篇,将List<Menu>的扁平结构数据, 转换成树形结构的数据 返回给前端 , 废话不多说,开撸!
---------------------
步骤:
1. 建 Menu实体结构
public class Menu
{
/// <summary>
/// ID
/// </summary>
public int ID { get; set; }
/// <summary>
/// 菜单名
/// </summary>
public string MenuName { get; set; }
/// <summary>
/// 父菜单
/// </summary>
public int ParentID { get; set; }
}
2. 建Tree 的数据结构(用来做树形结构的数据返回)
public class Tree
{
/// <summary>
/// ID
/// </summary>
public int ID { get; set; }
/// <summary>
/// 菜单名
/// </summary>
public string MenuName { get; set; }
/// <summary>
/// 父菜单
/// </summary>
public int ParentID { get; set; } /// <summary>
/// 子节点集合
/// </summary>
public List<Tree> Children { get; set; }
}
3. 写方法,递归遍历,将Menu实体值赋值给Tree
//根据父节点获取子节点
public static List<Tree> GetChildTree(List<Menu> list, int Id)
{ List<Tree> tree = new List<Tree>();
List<Menu> ChildList = GetChildList(list, Id);
foreach (var item in ChildList)
{
Tree treeB = new Tree();
treeB.ID = item.ID;
treeB.MenuName = item.MenuName;
treeB.Children = GetChildTree(list,item.ID);
tree.Add(treeB);
}
return tree;
} public static List<Menu> GetChildList(List<Menu> list,int Id)
{
var childList = list.Where(x => x.ParentID == Id).ToList();
return childList;
}
4. 准备数据,方法调用
// 准备要处理的数据
List<Menu> listB = new List<Menu>();
listB.Add(new Menu { ID = , MenuName = "菜单1", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.1", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.1.1", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.1.2", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.2", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.2.2", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单2", ParentID = }); var result = GetChildTree(listB, );
string jsonB = new JavaScriptSerializer().Serialize(result);
5. 转换后的树形结构数据结果图示

-----------------------开发过程中遇到的问题---------------------------------
从别人的博客看到这种方式,很高兴,以为改改,很快就可以实现工作中的功能,结果发现还欠缺点东西,就是要传入的父节点Id值给定的是0 ,写死的。
而我要传入的这个Id值要是动态的,要根据传入的List集合,找出这个集合数据里面的根节点的Id值。 在这上面的代码中并没有给出, 于是我开始折腾,最终从别人的js 代码中找到了别人的解决思路。
我的解决方法如下,希望也能够帮助一些人:
// 准备要处理的数据
List<Menu> listB = new List<Menu>();
listB.Add(new Menu { ID = , MenuName = "菜单1", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.1", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.1.1", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.1.2", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.2", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单1.2.2", ParentID = });
listB.Add(new Menu { ID = , MenuName = "菜单2", ParentID = });
//找出集合里面的根节点的Id
HashSet<int> parentIds = new HashSet<int>();
HashSet<int> childIds = new HashSet<int>();
foreach (var item in listB)
{
childIds.Add(item.ID);
parentIds.Add(item.ParentID);
}
parentIds.ExceptWith(childIds);
int rootId = parentIds.First(); var result = GetChildTree(listB, rootId);
最后,发表一下感慨,C# 写的代码真的少,7、8行就解决了!
C# 把带有父子关系的数据转化为------树形结构的数据 ,以及 找出父子级关系的数据中里面的根数据Id的更多相关文章
- 关于mysql中数据存储复合树形结构,查询时结果按树形结构输出
1.主要思想:根据已有数据,规则性的造数据 select * FROM(select lId,strName,lId as lParentId,-1 as orderIdx from tbClassi ...
- js中把ajax获取的数据转化成树状结构(并做成多级联动效果)
1.首先通过ajax获取数据,此处省略,直接贴出获取到的数据格式 var arr = [{ id: 1, name: "一级标题", pid: 0 }, { id: 2, name ...
- Oracle恢复删除数据 && connect by 树形结构查询
1.一个表中根据以父子级别关系查询显示出来(如图) select t.* from department t CONNECT BY PRIOR t.depid=t.supdepid ; --这样也可以 ...
- Vue组件模板形式实现对象数组数据循环为树形结构
数据结构为数组中包含对象--树形结构,用Vue组件的写法实现以下的效果: 树形列表,缩进显示层级,第5级数据加底色,数据样式显色,点击展开折叠数据.本文为用Vue实现方式,另有一篇为用knockout ...
- js把json数据转化成树形数据
/*转化函数*/ function(data, attributes) { let resData = data; let tree = []; for(let i = 0; i < resDa ...
- JavaScript 将行结构数据转化为树形结构,可提供给常用的tree插件直接使用(高效转化方案)
前台接收到的数据格式 var rows=[{ parent: 'root', id: 'DC', title: '集团' }, { parent: 'DC', id: '01', title: '上海 ...
- JS 将有父子关系的数组转换成树形结构数据
将类似如下数据转换成树形的数据 [{ id: 1, name: '1', }, { id: 2, name: '1-1', parentId: 1 }, { id: 3, name: '1-1-1', ...
- SQL Server 2008中新增的变更数据捕获(CDC)和更改跟踪
来源:http://www.cnblogs.com/downmoon/archive/2012/04/10/2439462.html 本文主要介绍SQL Server中记录数据变更的四个方法:触发器 ...
- ionic中将service中异步返回的数据赋值给controller的$scope
1.service中异步获取数据实例 angular.module('starter.services', []) .factory('Chats', function($http,$q) {//定义 ...
随机推荐
- iOS多线程编程原理及实践
摘要:iOS开发中,开发者不仅要做好iOS的内存管理,而且如果你的iOS涉及多线程,那你也必须了解iOS编程中对多线程的限制,iOS主线程的堆栈大小为1M,其它线程均为512KB,且这个限制开发者是无 ...
- 开启我的python之路,第一节,git版本管理工具
git版本管理工具 一.git功能与结构 1.Git是分布式管理系统,服务端和客户端都有版本控制功能,都能进行代码的提交,合并 2.git分为工作区,暂存区,本地仓库和远程仓库 二.git安装与查看 ...
- Nginx安装目录讲解
查看nginx相关目录 rpm -ql nginx 查看到如下目录 /etc/logrotate.d/nginx 配置文件 作用:nginx日志轮转,用于logrotate(轮替)服务的日志切割 /e ...
- ORM基础3 在python脚本里调用Django环境
1.查询 1.# all获取所有的object,结果QuerySet,列表 print('all'.center(80, '=')) ret = models.Person.objects.all() ...
- 异数OS谈发展国产操作系统的问题
异数OS谈发展国产操作系统的问题 为什么写本文 最近中兴被美制裁的问题以及红芯使用开源技术宣称国产自主技术引发了舆论不少对国产CPU以及国产操作系统自主技术的讨论,为什么我们国家有BAT,有原子弹,能 ...
- 【java面试】Web篇
1.AJAX创建步骤 step1. 创建XMLHttpRequest对象,也就是创建一个异步调用对象: step2. 创建一个新的HTTP请求,并指定改HTTP请求的方法.URL以及验证信息: s ...
- 手把手写一个基于Spring Boot框架下的参数校验组件(JSR-303)
前言 之前参与的新开放平台研发的过程中,由于不同的接口需要对不同的入参进行校验,这就涉及到通用参数的校验封装,如果不进行封装,那么写出来的校验代码将会风格不统一.校验工具类不一致.维护风险高等其它因素 ...
- 使用Razor表达式 举数组和集合 精通ASP-NET-MVC-5-弗瑞曼
- ugui制作伸缩菜单
制作一个类似与这种格式的菜单,可以伸缩滑动的.今天正好项目需要用到类似功能,所以尝试了一下,做出如下的效果 虽然只是一个思路,但是可以扩展.声明一个object物体,为but,通过GetCompone ...
- makefile自动依赖生成
自动依赖生成 基于make的构建环境要正确工作, 一个很重要(也很烦人)的任务是, 在makefile中正确列 举依赖. 这个文档将介绍了一个非常有用的让make自身来创建和维护这些依赖的方法. 文章 ...