如何构造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. show()封装没有想象中那么简单

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. mysql获取表中日期的年月日时分秒

    SELECT year(callTheRollTime) from schedule_account 获取年 SELECT month(callTheRollTime) from schedule_a ...

  3. 基于Token认证的多点登录和WebApi保护

    在文章中有错误的地方,或是有建议或意见的地方,请大家多多指正,邮箱: linjie.rd@gmail.com 一天张三,李四,王五,赵六去动物园,张三没买票,李四制作了个假票,王五买了票,赵六要直接F ...

  4. 从git仓库导入idea的gradle项目无法添加依赖包问题

    引言 之前将项目导入到git仓库,后来同事从git仓库将项目导入到本地,发现无法导入依赖包. 解决方法 这个勾idea是默认勾上的,意思是idea将默认使用本地离线工作模式,使用的是本地仓库,每次依赖 ...

  5. Spring Boot整合Mybatis并完成CRUD操作

    MyBatis 是一款优秀的持久层框架,被各大互联网公司使用,本文使用Spring Boot整合Mybatis,并完成CRUD操作. 为什么要使用Mybatis?我们需要掌握Mybatis吗? 说的官 ...

  6. css公共库——简介中超过长度显示省略号

    在简介.引言中常见:文字只有一排,超出宽度以省略号显示,像这样 实现方法:在公共库定义otw类 .otw{ overflow: hidden; text-overflow: ellipsis; whi ...

  7. 全球排名第一的开源ERP Odoo v12 最新一键安装体验版正式发布

    引言 Odoo 12.0是目前全球Odoo社区最新推出的产品版本代号,该产品具有划时代的意义,增加了如互联网级的知识库网盘功能.工业互联网的IOT设备矩阵管控功能,全新的Python Sass前端引擎 ...

  8. PyCharm 如何远程连接服务器编写程序

    写在前面 我之前一直通过mstsc远程服务器桌面修改代码,或者本地修改后上传到远程服务器等,各种不爽,现在改用xshell,但有时候还是感觉不方便.于是乎,自己动手配置PyCharm远程连接服务器,这 ...

  9. WireShark捕获HTTPS

    firefox,chrome会将 TLS 会话中使用的对称密钥保存在外部文件中. 1.建立环境变量 linux,mac 使用export建立变量:export SSLKEYLOGFILE=/tmp/s ...

  10. 华为云.NET Core支持情况调查

    各大公有云都提供了开发者开发的SDK,今天我们来看看华为云对.NET Core的支持情况怎么样? .NET SDK地址 https://developer.huaweicloud.com/sdk#.N ...