C#匿名委托实现递归,将所有部门根据上下级关系显示在一个列表中,用于展示到下拉框中

该代码实现了一个方法,用于从数据库获取所有部门,并根据父级关系构建一个树形结构,以便在下拉框中展示。通过递归函数,每个部门节点包含其子部门信息,同时计算层级。部门类包含ID、名称、父ID、排序号和状态等属性,还有一系列扩展字段用于辅助表示层级和子集存在状态。
摘要由CSDN通过智能技术生成
/// <summary>
/// 将所有部门根据上下级关系显示在一个列表中,用于展示到下拉框中
/// </summary>
/// <returns></returns>
public async Task<List<Department>> GetTreeDepartment()
{
    await Task.Yield();
    var listAll = GetAllDepartment();
    List<Department> tree = new List<Department>();

    //一级
    var list_01 = listAll.Where(x => string.IsNullOrWhiteSpace(x.Parent_id));

    Action<Department, List<Department>> func = null;
    func = (q, list) =>
    {
        //查找子集
        var child = listAll.Where(x => x.Parent_id == q.Id);

        //是否有子集,1=有,0=无
        q.E2=child?.Count()>0? "1":"0";

        list.Add(q);
        if (child != null && child.Count() > 0)
        {
            foreach (var item in child)
            {
                //计算层级
                item.E7 = q.E7 + 1;
                func(item, list);
            }
        }
    };

    foreach (var item in list_01)
    {
        //计算层级
        item.E7 = 1;
        func(item, tree);
    }
    return tree;
}
  

    /// <summary>
    /// 部门
    /// </summary>
    public class Department : BaseEntity
    {
        /// <summary>
        /// 主键
        /// </summary>
        [Key]
        public string Id { get; set; }

        /// <summary>
        /// 部门名称
        /// </summary>
        public string Department_name { get; set; }

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

        /// <summary>
        /// 排序
        /// </summary>
        public int Sno { get; set; }

        /// <summary>
        /// 是否启用,1=启用,0=禁用
        /// </summary>
        public byte? State { get; set; }
    }
   /// <summary>
    /// 扩展字段
    /// </summary>
    public class BaseEntity
    {
        /// <summary>
        /// 扩展字段
        /// </summary>
        [NotMapped]
        public string E1 { get; set; }

        /// <summary>
        /// 扩展字段
        /// </summary>
        [NotMapped]
        public string E2 { get; set; }

        /// <summary>
        /// 扩展字段
        /// </summary>
        [NotMapped]
        public string E3 { get; set; }

        [NotMapped]
        public string E4 { get; set; }

        [NotMapped]
        public string E5 { get; set; }

        [NotMapped]
        public string E6 { get; set; }

        /// <summary>
        /// 扩展字段
        /// </summary>
        [NotMapped]
        public int E7 { get; set; }

        [NotMapped]
        public List<string> List1 { get; set; } = new List<string>();

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王焜棟琦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值