c#递归生成web界面Tree的json数据

1 篇文章 0 订阅
1 篇文章 0 订阅

 static void Main(string[] args)
        {
            string conStr = ConfigurationManager.ConnectionStrings["ConsoleApplication1.Properties.Settings.FMS_AConnectionString"].ToString();
            SqlConnection con = new SqlConnection(conStr);
            con.Open();
            SqlDataAdapter dap = new SqlDataAdapter("select mid,featherId,mName from Menue with(nolock)", con);
            DataTable dt = new DataTable();
            dap.Fill(dt);
            con.Close();

           string result= GetTreeNode(dt);

           Console.WriteLine(result);
        }
      
        private  static string GetTreeNode(DataTable dt) {
            string result = string.Empty;
            try
            {
                DataRow[] dView = dt.Select("featherId=0");
                List<treeNode> _treeNodeList = new List<treeNode>();
                foreach (DataRow dr in dView)
                {
                    _treeNodeList.Add(new treeNode() {
                        id = int.Parse(dr["mid"].ToString()),
                        pid = int.Parse(dr["featherId"].ToString()),
                        text = dr["mName"].ToString(),
                        children = GetChildrenTreeNode(int.Parse(dr["mid"].ToString()), dt)
                    });
                    result = JsonConvert.SerializeObject(_treeNodeList);
                }
               
            }
            catch (Exception e)
            {
                result = e.Message;
            }
            return result;
        }
       

         /// <summary>
        /// 
        /// </summary>
        /// <param name="mid">唯一值(主键)</param>
        /// <param name="featherId">父Id</param>
        /// <param name="dt"></param>
        /// <returns></returns>
        private static  List<treeNode> GetChildrenTreeNode(int mid, DataTable dt) {
            DataRow[] dView = dt.Select("featherId="+mid);
            List<treeNode> _childrenList = new List<treeNode>();
            foreach (DataRow dr in dView)
            {
                _childrenList.Add(new treeNode() {
                    id = int.Parse(dr["mid"].ToString()),
                    pid = int.Parse(dr["featherId"].ToString()),
                    text = dr["mName"].ToString(),
                    children = GetChildrenTreeNode(int.Parse(dr["mid"].ToString()), dt)
                });
            }
            return _childrenList;

        }
        public class treeNode {
            public int id { get; set; }
            public int pid { get; set; }
            public string text { get; set; }
            public List<treeNode> children { get; set; }
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值