C#使用递归算法给TreeView控件绑定数据

/// <summary>
        /// 查找根节点(parent_ID为0的节点)的子节点
        /// </summary>
        /// <param name="parent_ID">参数,接收根节点ID即0</param>
        public void bindtree(string parent_ID)
        {
            this.tvgood.Nodes.Clear();
            DataTable dt = frmgb.Getdata(parent_ID);
            if (dt.Rows.Count > 0)
            {
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    TreeNode node = new TreeNode();
                    node.Text = dt.Rows[i]["gt_Name"].ToString();
                    node.Tag = dt.Rows[i]["gt_ID"].ToString();
                    DataTable dt1 = frmgb.Getdata(node.Tag.ToString());
                    this.tvgood.Nodes.Add(node);//把指定节点添加到控件中
                    frmgb.bindnode(node);//递归遍历制定节点下的子节点
                }
            }
        }

        /// <summary>
        /// 递归遍历指定节点下的子节点
        /// </summary>
        /// <param name="nd">参数,接收节点对象</param>
        public void bindnode(TreeNode nd)
        {
            try
            {
                DataTable dt = Getdata(nd.Tag.ToString());
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    TreeNode node = new TreeNode();
                    node.Text = dt.Rows[i]["gt_Name"].ToString();
                    node.Tag = dt.Rows[i]["gt_ID"].ToString();
                    DataTable dt1 = Getdata(node.Tag.ToString());
                    nd.Nodes.Add(node);//把指定节点添加到控件中
                    bindnode(node);
                }
            }
            catch (Exception error)
            {
                throw error;
            }
        }

 /// <summary>
        /// 从数据库中查找指定节点(ID)的子节点
        /// </summary>
        /// <param name="ID">参数</param>
        /// <returns>返回DataSet</returns>
        public DataTable Getdata(string ID)
        {
            try
            {
                DataTable dt = Query.ProcessSql("select * from POS_GoodsType where  gt_FatherNode=" + ID, Constants.DBNAME);
                return dt; //返回含有ID的数据
            }
            catch (Exception error)
            {
                throw error;
            }
        }

点击节点查询类型下的所属商品时目标明确将父节点和所有子节点循环拼接起来字符串在商品表中根据GoodType in (2,3)去查

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值