C# 构造tree菜单工具方法
如何构造tree数据结构,做个笔记,方便查阅,本方法是直接返回json字符串:
private string ToMenuJson(List<Model> data, string parentId)
{
var sbJson = new StringBuilder();
sbJson.Append("[");
var entitys = data.FindAll(t => t.ParentID == parentId).ToList();
if (entitys.Count > )
{
foreach (var item in entitys)
{
var strJson = JsonConvert.SerializeObject(item, new JsonSerializerSettings { ReferenceLoopHandling = ReferenceLoopHandling.Ignore });
strJson = strJson.Insert(strJson.Length - , ",\"ChildNodes\":" + ToMenuJson(data, item.ID) + "");
sbJson.Append(strJson + ",");
}
sbJson = sbJson.Remove(sbJson.Length - , );
}
sbJson.Append("]");
return sbJson.ToString();
}
本方法是构造tree实体,返回实体:
/// <summary>
/// 绑定列表递归方法
/// </summary>
/// <param name="ddl">构造tree数据结构返回的实体</param>
/// <param name="menus">绑定的数据源</param>
/// <param name="categoryid">父级id值</param>
private void BindChannelType(List<ECategoryModel> ddl, List<ECategory> menus, Guid categoryid)
{
List<ECategory> filterMenu = menus.Where(w => w.ParentID == categoryid).ToList(); foreach (var m in filterMenu)
{
var mextend = new ECategoryModel
{
ID = m.ID,
ParentID = m.ParentID,
CategoryName = m.CategoryName,
URL = m.URL,
Sort = m.Sort,
IsDelete = m.IsDelete
};
ddl.Add(mextend);
BindChannelType(mextend.children, menus, m.ID);
}
}
构造树形数据(带空格和缩进):
/// <summary>
/// 构造树形下拉框数据结构
/// </summary>
private void Generate(List<ECategoryModel> viewList, List<ECategory> categories, Guid categoryid, int i = 0)
{
i++;
var filterMenu = categories.Where(w => w.ParentID == categoryid).OrderBy(w => w.Sort).ToList(); foreach (var m in filterMenu)
{
var str = "";
//父级菜单不缩进
for (var j = 1; j < i; j++)
{
str += HttpUtility.HtmlDecode(" ") + "├";
} var mextend = new ECategoryModel
{
ID = m.ID,
ParentID = m.ParentID,
CategoryName = $"{str}{m.CategoryName}",
URL = m.URL,
iconSkin = m.URL,
Sort = m.Sort,
IsDelete = m.IsDelete
};
viewList.Add(mextend);
Generate(viewList, categories, m.ID, i);
}
}
相关的实体类 ECategoryModel.cs:
using System;
using System.Collections.Generic; namespace MSEduPlatform.Models
{
/// <summary>
/// ECategory表实体类
/// </summary>
public class ECategoryModel
{
/// <summary>
/// 菜单ID
/// </summary>
public Guid ID { get; set; } /// <summary>
/// 父级菜单ID
/// </summary>
public Guid ParentID { get; set; } /// <summary>
/// 菜单Code
/// </summary>
public string Code { get; set; } /// <summary>
/// 菜单名称
/// </summary>
public string CategoryName { get; set; } /// <summary>
/// 菜单地址
/// </summary>
public string URL { get; set; } /// <summary>
/// 菜单排序
/// </summary>
public int Sort { get; set; } /// <summary>
/// 显示状态
/// </summary>
public int States { get; set; } /// <summary>
/// 栏目权限类别
/// </summary>
public string AuthorizationType { get; set; } /// <summary>
/// 是否授权
/// </summary>
public bool IsAuthorization { get; set; } /// <summary>
/// 创建人
/// </summary>
public Guid Creater { get; set; } /// <summary>
/// 创建时间
/// </summary>
public DateTime CreateTime { get; set; } /// <summary>
/// 修改人
/// </summary>
public Guid Modify { get; set; } /// <summary>
/// 修改时间
/// </summary>
public DateTime ModifyTime { get; set; } /// <summary>
/// 是否逻辑删除
/// </summary>
public int IsDelete { get; set; } /// <summary>
/// 子数据列表
/// </summary>
public List<ECategoryModel> children = new List<ECategoryModel>();
}
}
C# 构造tree菜单工具方法的更多相关文章
- Make Things Move -- Javascript html5版(一)文件目录结构和工具方法准备
从这一篇开始,就来开始我们的make things move之旅吧 在此之前,要知道ActionScript(AS)的语法和JS是不一样的,AS是相对于JS而言更好的支持了面向对象的特性,所以我们可以 ...
- PHP+Mysql+easyui点击左侧tree菜单对应表名右侧动态生成datagrid加载表单数据(二)
关于tree菜单生成,参考我的另一篇博文地址tree 菜单 实现功能:点击左侧tree菜单中的table,右侧通过datagrid加载出该表对用的所有数据 难点:获取该表的所有列名,动态生成datag ...
- WordPress插件制作教程(三): 添加菜单的方法
上一篇编写了一个简单的插件,让大家对插件的简单制作有个了解,这一篇我们在更深一步,当我们激活插件后后台会显示菜单出来,然后通过单击菜单显示自己定义好的信息.激活之后会在WordPress后台显示一个菜 ...
- Extjs中创建Tree菜单【一】
此篇treepanel的描写是很简单,没有太大的难度,在学习时,可以先熟悉tree的一些配置信息.属性.方法和事件. 然后先写一个简单的例子,慢慢了解从中如何实现的,然后在慢慢的深入了解,实现一些复杂 ...
- JQuery extend()与工具方法、实例方法
使用jQuery的时候会发现,jQuery中有的函数是这样使用的: $.get(); $.post(); $.getJSON(); 有些函数是这样使用的: $('div').css(); $('ul' ...
- 如何使用 JSP JSTL 显示/制作树(tree) 菜单
JSTL里面并没有直接制作tree菜单的元素,因此递归是JSP JSTL显示/制作tree菜单的唯一方法. 以下详述如何制作tree菜单. 首先,在主页面里面增加包含制作树菜单的jsp,例如: 在my ...
- jquery 源码学习(四)构造jQuery对象-工具函数
jQuery源码分析-03构造jQuery对象-工具函数,需要的朋友可以参考下. 作者:nuysoft/高云 QQ:47214707 EMail:nuysoft@gmail.com 声明:本文为原 ...
- JQuery操作类数组的工具方法
JQuery学习之操作类数组的工具方法 在很多时候,JQuery的$()函数都返回一个类似数据的JQuery对象,例如$('div')将返回div里面的所有div元素包装的JQuery对象.在这中情况 ...
- jQuery工具方法
目录 常用工具方法 判断数据类型的方法 Ajax操作 $.ajax 简便写法 Ajax事件 返回值 JSONP 文件上传 参考链接 jQuery函数库提供了一个jQuery对象(简写为$),这个对象本 ...
随机推荐
- 计算机17-1,2作业D
D.环形矩阵 Description 给定一个整数m,按m形成一个环形矩阵.如m=5,则环形矩阵为: 1 1 1 1 1 1 1 1 1 1 2 2 ...
- 【BAT面试题系列】面试官:你了解乐观锁和悲观锁吗?
前言 乐观锁和悲观锁问题,是出现频率比较高的面试题.本文将由浅入深,逐步介绍它们的基本概念.实现方式(含实例).适用场景,以及可能遇到的面试官追问,希望能够帮助你打动面试官. 目录 一.基本概念 二. ...
- 鸟哥的Linux私房菜笔记第四章
前言 对着<鸟哥的Linux私房菜-基础版>做了简化笔记.不想让自己知其然而不知其所然.所以写个博客让自己好好巩固一下,当然不可能把书中的内容全部写下来.在这里就简化一点把命令写下来. 让 ...
- [AST实战]从零开始写一个wepy转VUE的工具
为什么需要 wepy 转 VUE "转转二手"是我司用 wepy 开发的功能与 APP 相似度非常高的小程序,实现了大量的功能性页面,而新业务 H5 项目在开发过程中有时也经常需要 ...
- MySQL数据同步,出现Slave_SQL_Running:no和slave_io_running:no问题的解决方法
一.问题描述: 当我们配置好MySQL主主同步时,是可以实现主主同步,但是重启机器后就发现无法同步了. 二.Slave两个关键进程: mysql replication 中slave机器上有两个关键的 ...
- 图解Java线程的生命周期,看完再也不怕面试官问了
文章首发自个人微信公众号: 小哈学Java https://www.exception.site/java-concurrency/java-concurrency-thread-life-cycle ...
- .net core 注入中的三种模式:Singleton、Scoped 和 Transient
从上篇内容不如题的文章<.net core 并发下的线程安全问题>扩展认识.net core注入中的三种模式:Singleton.Scoped 和 Transient 我们都知道在 Sta ...
- [翻译 EF Core in Action 1.10] 应该在项目中使用EF Core吗?
Entity Framework Core in Action Entityframework Core in action是 Jon P smith 所著的关于Entityframework Cor ...
- Asp.NetCore轻松学-使用Supervisor进行托管部署
前言 上一篇文章 Asp.NetCore轻松学-部署到 Linux 进行托管 介绍了如何在 Centos 上部署自托管的 .NET Core 应用程序,接下来的内容就是介绍如何使用第三方任务管理程序来 ...
- spring boot 2.0 Feign的客户端
1.pom.xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId ...