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对象(简写为$),这个对象本 ...
随机推荐
- nginx用户认证与htpasswd命令
最近在搭建ELK,然后ELK的kibana界面想添加一个访问限制,看到kibana有个插件x-pack,本来想用用,发现是收费的,就放弃了,然后就想着想配置下nginx的认证访问来实现简单的访问登陆. ...
- 【公告】MIP组件审核平台故障-影响说明
故障通报 2017年8月8日 下午14:11,由于机器故障原因,MIP组件审核平台无法提供服务. 2017年8月8日 下午16:46,服务恢复. 故障影响 2017年8月8日下午13:00-14:00 ...
- 描述性统计指标 - 众数 Mode
定义- 数值型数据 - 出现频数最多的变量值- 品质型数据.单项式分组数据 - 频数最多的组为众数组,该组的变量值(类型)就是众数- 组距式分组数据 - 频数最多的组为众数组,通过公式求得众数 - 公 ...
- Ethercat 学习总结一:协议总结
原文地址:https://blog.csdn.net/qq923433160/article/details/83781812 EtherCAT 总线的国家标准相关资料,比较详细介绍了协议: http ...
- 【开源】OSharpNS,轻量级.net core快速开发框架发布
OSharpNS简介 OSharp Framework with .NetStandard2.0(OSharpNS)是OSharp的以.NetStandard2.0为目标框架,在AspNetCore的 ...
- captcha.js一个生成验证码的插件,使用js和canvas生成
一.captcha`captcha.js`是一个生成验证码的插件,使用js和canvas生成的,确保后端服务被暴力攻击,简单判断人机以及系统的安全性,体积小,功能多,支持配置. 验证码插件内容,包含1 ...
- 手写DotNet Core 认证授权代码
在普通的MVC项目中 我们普遍的使用Cookie来作为认证授权方式,使用简单.登录成功后将用户信息写入Cookie:但当我们做WebApi的时候显然Cookie这种方式就有点不适用了. 在dotnet ...
- 第65章 博客帖子 - Identity Server 4 中文文档(v1.0.0)
第65章 博客帖子 65.1 团队帖子 65.1.1 2019 IdentityServer中的范围和声明设计 尝试使用IdentityServer4的设备流程 OAuth2中隐含流的状态 另一种保护 ...
- vue 中使用promise
init1(){return new Promise((resolve, reject) => { let data={ dateStr:this.time }; api.get('url', ...
- arcgis api 4.x for js 结合 react 入门开发系列初探篇(附源码下载)
你还在使用 JQuery 或者 Dojo 框架开发 arcgis api 4.x for js 吗?想试试模块化开发吗?随着前端技术的发展,arcgis api 4.x for js 也有了结合 re ...