如何构造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. 【h5+c3】web前端实战项目、快装webapp手机案例源码

    快装WebApp项目(Web移动端开发案例)webapp移动端项目源码.html5+css3实战案例分享.微信端H5实例开发 简介快装WebApp是一个面向移动端的快速装修app,此项目为手机端:使用 ...

  2. APP界面设计与页面布局的23条基本原则

    一个App的好与不好,很大部分取决于移动App页面布局的合理性,优秀的布局顾名思义就是对页面的文字.图形或表格等进行排版.设计. 优秀的布局,需要对页面信息进行完整的考虑,既要考虑用户需求.用户行为, ...

  3. [asp.net mvc 奇淫巧技] 06 - 也许你的项目同一个用户的请求都是同步的

    一.感慨 很久前看到一篇博客中有句话大致的意思是:“asp.net 程序性能低下的主要原因是开发人员技术参差不齐”,当时看到这句话不以为然,然而时间过的越久接触的.net 开发人员越多就越认同这句话: ...

  4. 分享自己写的一个.net方法缓存源码

    在服务器性能优化中,我们更多的是要考虑到缓存的使用,分享一个自己编写的方法缓存的框架,使用非常方便.话不多说,先上使用例子: 1.定义要使用缓存的类及方法: public class Example ...

  5. DSAPI 调用串口选择界面

    在DSAPI中,可以通过简单的代码调用串口选择界面,当用户选择了其中一个串口时,将返回选择的串口名称(或序号). Dim 串口名称 As String = DSAPI.串口通讯.显示串口选择界面.选择 ...

  6. C# 数组比较--取得两个集合的交集,差集,并集的方法

    方法关键字: 交集:Intersect 差集:Except 并集:Union 使用代码: , , , , }; , , , , }; var 交集 = arr1.Intersect(arr2).ToL ...

  7. Java集合 - List介绍及源码解析

    (源码版本为 JDK 8) 集合类在java.util包中,类型大体可以分为3种:Set.List.Map. JAVA 集合关系(简图) (图片来源网络) List集合和Set集合都是继承Collec ...

  8. Geoserver+Openlayers拉框查询

    1.代码 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" co ...

  9. sql语句 汉字转拼音首字母

    (1)------------------------------------------------------------------------------------------------- ...

  10. 如何在eclipse中快速debug到想要的参数条件场景下

    前言 俗话说,工欲善其事必先利其器. 对于我们经常使用的开发工具多一些了解,这也是对我们自己工作效率的一种提升. 场景 作为开发,我们经常会遇到各种bug,大部分的bug很明确,我们直接可以打断点定位 ...