C# 一次循环获取树的两种方法
2024-09-06 18:04:19
第一种方法好些
第二种方法如果中间断开就会成为一级
private static List<Menu> MenuTree()
{
var menu1 = new Menu { Id = , ParentId = , Name = "aaa" };
var menu2 = new Menu { Id = , ParentId = , Name = "bbb" };
var menu3 = new Menu { Id = , ParentId = , Name = "ccc" };
var menu4 = new Menu { Id = , ParentId = , Name = "ddd" };
var menu5 = new Menu { Id = , ParentId = , Name = "eee" };
var menu6 = new Menu { Id = , ParentId = , Name = "fff" };
var menu7 = new Menu { Id = , ParentId = , Name = "ggg" };
var menu8 = new Menu { Id = , ParentId = , Name = "hhh" };
var menuAll = new List<Menu> { menu1, menu2, menu3, menu4, menu5, menu6, menu7, menu8 };
var menuList = new List<Menu> { menu1, menu2, menu3, menu4, menu5, menu7, menu8 };
//第一种方法
while (true)
{
var idList = menuList.Select(x => x.Id).ToList();
idList.AddRange(menuList.Select(x => x.ParentId).ToList());
idList = idList.Distinct().ToList();
var menus = menuAll.Where(x => idList.Contains(x.Id)).ToList();
if (menus.Count != menuList.Count)
{
menuList = menus;
continue;
} break;
}
//第二种方法
var ret = new List<Menu>();
foreach (var menu in menuList)
{
var model = menuList.FirstOrDefault(x => x.Id == menu.ParentId);
if (model == null)
{
ret.Add(menu);
continue;
} model.Children.Add(menu);
} return ret;
}
最新文章
- Android studio
- Security6:授予权限的思路和一般步骤
- 运用webkit绘制渲染页面原理解决iscroll4闪动的问题
- 从零自学Hadoop(07):Eclipse插件
- 重读C#委托、事件有感
- mysql 在linux 修改账号密码
- c# winform 全角自动转化半角问题(C#中ImeMode的值):转载
- web设计经验<;九>;教你测试手机网页的5大方法
- web.xml中contextConfigLocation的作用
- CodeForces 135 B. Rectangle and Square(判断正方形和 矩形)
- php nl2br() 函数
- 使用Xcode Instruments Leak解决内存泄漏问题
- html简单定位
- STM32开发指南-DMA
- 使用 Router 实现的模块化,如何优雅的回到主页面
- dede从www跟目录迁移,网站空间
- Django 简介
- SpringBoot集成spring-data-jpa注入Bean失败
- 【arc073e】Ball Coloring(线段树,贪心)
- springboot集成mybatis环境搭建以及实现快速开发微服务商品模块基本的增删改查!