如何构造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("&nbsp;&nbsp;") + "├";
} 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菜单工具方法的更多相关文章

  1. Make Things Move -- Javascript html5版(一)文件目录结构和工具方法准备

    从这一篇开始,就来开始我们的make things move之旅吧 在此之前,要知道ActionScript(AS)的语法和JS是不一样的,AS是相对于JS而言更好的支持了面向对象的特性,所以我们可以 ...

  2. PHP+Mysql+easyui点击左侧tree菜单对应表名右侧动态生成datagrid加载表单数据(二)

    关于tree菜单生成,参考我的另一篇博文地址tree 菜单 实现功能:点击左侧tree菜单中的table,右侧通过datagrid加载出该表对用的所有数据 难点:获取该表的所有列名,动态生成datag ...

  3. WordPress插件制作教程(三): 添加菜单的方法

    上一篇编写了一个简单的插件,让大家对插件的简单制作有个了解,这一篇我们在更深一步,当我们激活插件后后台会显示菜单出来,然后通过单击菜单显示自己定义好的信息.激活之后会在WordPress后台显示一个菜 ...

  4. Extjs中创建Tree菜单【一】

    此篇treepanel的描写是很简单,没有太大的难度,在学习时,可以先熟悉tree的一些配置信息.属性.方法和事件. 然后先写一个简单的例子,慢慢了解从中如何实现的,然后在慢慢的深入了解,实现一些复杂 ...

  5. JQuery extend()与工具方法、实例方法

    使用jQuery的时候会发现,jQuery中有的函数是这样使用的: $.get(); $.post(); $.getJSON(); 有些函数是这样使用的: $('div').css(); $('ul' ...

  6. 如何使用 JSP JSTL 显示/制作树(tree) 菜单

    JSTL里面并没有直接制作tree菜单的元素,因此递归是JSP JSTL显示/制作tree菜单的唯一方法. 以下详述如何制作tree菜单. 首先,在主页面里面增加包含制作树菜单的jsp,例如: 在my ...

  7. jquery 源码学习(四)构造jQuery对象-工具函数

    jQuery源码分析-03构造jQuery对象-工具函数,需要的朋友可以参考下.   作者:nuysoft/高云 QQ:47214707 EMail:nuysoft@gmail.com 声明:本文为原 ...

  8. JQuery操作类数组的工具方法

    JQuery学习之操作类数组的工具方法 在很多时候,JQuery的$()函数都返回一个类似数据的JQuery对象,例如$('div')将返回div里面的所有div元素包装的JQuery对象.在这中情况 ...

  9. jQuery工具方法

    目录 常用工具方法 判断数据类型的方法 Ajax操作 $.ajax 简便写法 Ajax事件 返回值 JSONP 文件上传 参考链接 jQuery函数库提供了一个jQuery对象(简写为$),这个对象本 ...

随机推荐

  1. 基于JavaMail开发邮件发送器工具类

    基于JavaMail开发邮件发送器工具类 在开发当中肯定会碰到利用Java调用邮件服务器的服务发送邮件的情况,比如账号激活.找回密码等功能.本人之前也碰到多次这样需求,为此特意将功能封装成一个简单易用 ...

  2. Adobe Photoshop CC 2019 for Mac v20.0.4 中文版安装教程

    全新Adobe Photoshop CC 2019 mac特别版终于上线了,简称ps cc 2019,Adobe Photoshop CC 2019 for Mac v20.0.4 中文版安装教程分享 ...

  3. 从壹开始前后端分离 41 || Nginx+Github+PM2 快速部署项目(一)

    前言 哈喽大家周一好!今天是农历腊月二十三,小年开始,恭祝大家新年快乐(哈哈你五福了么

  4. 基于Raft深度优化,腾讯云金融级消息队列CMQ高可靠算法详解

    背景介绍 分布式系统是指一组独立的计算机,通过网络协同工作的系统,客户端看来就如同单台机器在工作.随着互联网时代数据规模的爆发式增长,传统的单机系统在性能和可用性上已经无法胜任,分布式系统具有扩展性强 ...

  5. 女皇武则天:我不愿被 extends

    01. 利用继承,我们可以基于已存在的类构造一个新类.继承的好处在于,子类可以复用父类的非 private 的方法和非 private 成员变量. is-a 是继承的一个明显特征,就是说子类的对象引用 ...

  6. 带着新人看java虚拟机05(多线程篇)

    上一篇我们主要是把一些基本概念给说了一下以及怎么简单的使用线程池,我们这一节就来看看线程池的实现: 1.线程池基本参数 以Executors.newFixedThreadPool()这种创建方式为例: ...

  7. box-shadow内阴影、外阴影

    外阴影: box-shadow:X轴  Y轴  Rpx  color; 属性说明(顺序依次对应):阴影的X轴(可以使用负值) 阴影的Y轴(可以使用负值) 阴影模糊值(大小) 阴影的颜色 内阴影: bo ...

  8. 企业自主可控免费开源ERP:Odoo采购管理解决方案

    供应商基础资料 1. 所有的供应商基础资料,Odoo开账启用时,期初的客户数据如果大于200条,可以批量导入: 2. 点“采购/采购/供应商”菜单可以查看.编辑修改.搜索所有的供应商基础资料: 3. ...

  9. Maven 基本的认识

    Maven 基本的认识 1. 什么是Maven? 在平时开发中,经常遇到某个jar包,我在代码层已经Import 和@Automation了,编译器还是提醒你某个jar包找不到,往往这时来个mvn i ...

  10. Flink源码分析 - 源码构建

    原文地址:https://mp.weixin.qq.com/s?__biz=MzU2Njg5Nzk0NQ==&mid=2247483692&idx=1&sn=18cddc1ee ...