list<类>树递归

//找出顶级项 
		List<PClass> listPParent = listP.FindAll(
                    delegate(PClass pc)
                    {
                        if (pc.ParentID == 0)//顶级项
                        {
                            return true;
                        }
                        {
                            return false;
                        }
                    }
                );

		if (listPParent.Count > 0)
                {
                    foreach (PClass itemParent in listPParent)
                    {
                        var result = new List<PClassView>();
                        var itemParentView = new PClassView()
                        {
                            ParentID = itemParent.ParentID,
                            ClassType = itemParent.ClassType,
                            ID = itemParent.ID
                        };
                        recursion(itemParent, result, listP, ""); //找出一个顶级项下的所有子项
                        list.Add(itemParentView);
                        list.AddRange(result);
                    }
                }

        /// <summary>
        /// 递归
        /// </summary>
        /// <param name="parentNode">当前节点</param>
        /// <param name="result">子节点</param>
        /// <param name="list">全部节点</param>
        /// <param name="strLevel">级数标志</param>
        private void recursion(PClass parentNode, IList<PClassView> result, IList<PClass> list, string strLevel)
        {
            strLevel = strLevel+"-";
            foreach (var item in from c in list where c.ParentID == parentNode.ID select c)
            {
                var child = new PClassView
                {
                    ParentID = item.ParentID,
                    ClassType = item.ClassType,
                    ID = item.ID,
                    Name = item.Name,
                    NameView=item.NameView
                };
                if (item.ParentID == null)
                {
                    result.Add(child);
                }
                else
                {
                    child.NameView = strLevel + child.NameView;
                    result.Add(child);
                }
                recursion(child, result, list, strLevel);
            }
        }







评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值