递归实现DropDownList层级

39 篇文章 1 订阅
        /// <summary>
        /// 绑定下拉框(分层级)
        /// </summary>
        /// <param name="dt">绑定的数据源</param>
        /// <param name="parentId">上一级的ID名称(数据列名称)</param>
        /// <param name="colId">下拉框值</param>
        /// <param name="colName">下拉框显示文本</param>
        /// <param name="drs">顶级集合</param>
        /// <param name="ddl">下拉框ID</param>
        /// <param name="leveStr">层级的前缀</param>
        /// <param name="nextStr">多层级的前缀</param>
        protected void GetChild(DataTable dt, string parentId, string colId, string colName, DataRow[] drs, DropDownList ddl, string leveStr, string nextStr)
        {
            foreach (DataRow dr in drs)
            {
                string txt = dr[colName].ToString();
                if (leveStr.Length != 1)
                {
                    txt = leveStr + dr[colName].ToString();
                }
                ddl.Items.Add(new ListItem(txt, dr[colId].ToString()));
                DataRow[] cdrs = dt.Select("n_parent_block_id=" + dr[colId]);
                if (cdrs.Length != 0)
                {
                    string nextLevelStr = leveStr.Insert(0, nextStr);
                    //string nextLevelStr = leveStr.Insert(0, "├");
                    GetChild(dt, parentId, colId, colName, cdrs, nextLevelStr, nextStr);
                }
            }
        }

这段代码调用方法:

DataTable dt = new APP_BLOCKAUTHBLL().GetListByCondition("", "1", this.Name, CodeBin.StaticData.Curopuser.C_User_Name);
            DataRow[] dr = dt.Select("n_parent_block_id=0");
            GetChild(dt, "0", "n_block_id", "c_block_name", dr,"—", "—");

此处实现了多层级的表现方式,满足需求,可以无限级,至于前缀可以更改的

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值