ASP.NET中递归绑定DDL下拉控件

做个记录,省得以后用到的时候都得再找以前写的代码,而且发现以前写的代码还有点错误的,但层级达到3层以上的时候就看得出错误在哪了,下面是更正后的代码:

// 绑定行政区域下拉列表
private void BindAreaDDL()
{
    ddl行政区域.Items.Clear();
    ddl行政区域.Items.Insert(0, new ListItem("", "0"));
    DataSet ds = new S_Area2DAO().GetList("");
    if (ds.Tables.Count > 0)
    {
        var query1 = ds.Tables[0].AsEnumerable().Where(x => x["parentid"].ToString() == "0");
        foreach (var item in query1)
        {
            ListItem li = new ListItem(item["name"].ToString(), item["id"].ToString());
            ddl行政区域.Items.Add(li);
            int index = 1;
            AddChildListItem(ds, item["id"].ToString(), index);
        }
    }
}
// 递归添加子项
private void AddChildListItem(DataSet ds, string pid, int index)
{
    int tmp = index;  // 保存层级
    // 计算前面的空白
    string space_str = "";
    for (int i = 0; i < index; i++)
    {
        space_str += "...";
    }


    var query1 = ds.Tables[0].AsEnumerable().Where(x => x["parentid"].ToString() == pid);
    foreach (var item in query1)
    {
        ListItem li = new ListItem(space_str + item["name"].ToString(), item["id"].ToString());
        ddl行政区域.Items.Add(li);
        index++;
        AddChildListItem(ds, item["id"].ToString(), index);
        index = tmp;  // 还原层级
    }
}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值