ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

树形结构的后端实现

2022-06-28 20:04:58  阅读:141  来源: 互联网

标签:node set string 实现 List public 树形 id 结构


1、增加Model模型结构

/// <summary>
        /// 子id
        /// </summary>
        public string Id { get; set; }

        /// <summary>
        /// 父id
        /// </summary>
        public string ParentId { get; set; }


        /// <summary>
        /// 名称
        /// </summary>
        public string Name { get; set; }

        /// <summary>
        /// 图标
        /// </summary>
        public string Icon { get; set; }

        /// <summary>
        /// 是否展开
        /// </summary>
        public bool Expanded { get; set; }=true;

        public bool Selected { get; set; } = true;

        /// <summary>
        /// 子节点
        /// </summary>
        public List<TreeModel> Children { get; set; }

        /// <summary>
        /// 无参构造函数
        /// </summary>
        public TreeModel()
        {
            Children = new List<TreeModel>();
        }

        /// <summary>
        /// 有参构造函数
        /// </summary>
        /// <param name="id">子id</param>
        /// <param name="name">名称</param>
        /// <param name="parentId">父id</param>
        public TreeModel(string id, string name, string parentId)
        {
            this.Id = id;
            this.Name = name;
            this.ParentId = parentId;
            Children = new List<TreeModel>();
        }

        /// <summary>
        /// 有参构造函数
        /// </summary>
        /// <param name="id">子id</param>
        /// <param name="name">名称</param>
        /// <param name="parent">父节点</param>
        public TreeModel(string id, string name, TreeModel parent)
        {
            this.Id = id;
            this.Name = name;
            this.ParentId = parent.Id;
            Children = new List<TreeModel>();
        }

2、递归实现树形结构的

/// <summary>
        /// 使用递归方法建树
        /// </summary>
        public static List<TreeModel> BulidTreeByRecursive(List<TreeModel> treeNodes, List<TreeModel> resps, string pID)
        {
            resps = new List<TreeModel>();
            List<TreeModel> tempList = treeNodes.Where(c => c.ParentId == pID).ToList();

            for (int i = 0; i < tempList.Count; i++)
            {
                TreeModel node = new TreeModel();
                node.Id = tempList[i].Id;
                node.ParentId = tempList[i].ParentId;
                node.Name = tempList[i].Name;
                node.Icon = tempList[i].Icon;
                node.Children = BulidTreeByRecursive(treeNodes, resps, node.Id);
                resps.Add(node);
            }


            return resps;
        }

3、然后基本实现,所属接口调用

标签:node,set,string,实现,List,public,树形,id,结构
来源: https://www.cnblogs.com/LSYLY97/p/16420835.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有