/// <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,"—", "—");
此处实现了多层级的表现方式,满足需求,可以无限级,至于前缀可以更改的
递归实现DropDownList层级
最新推荐文章于 2020-09-24 10:51:33 发布