将一个树形数据绑定到下拉列表当中:
表数据:
id name parentid
---------------------
-1 中国 0
-2 北京 -1
-3 广东 -1
-4 美国 0
-5 潮州 -3
-6 汕头 -3
-7 夏威夷 -4
想要实现这样的效果:
中国
北京
广东
潮州
汕头
美国
夏威夷
private void BindDropDownList()
{
DataTable dtSite;
DataRow[] dr = dtSite.Select("PARENTID=0");
for (int i=0; i<dr.Length; i++)
{
ddlSite.Items.Add(new ListItem(dr["NAME"].ToString(), dr["ID"].ToString()));
this.BindData(ddlSite, dtSite, dr["PARENTID"].ToString(), " ");
}
}
private void BindData(DropDownList ddlSite, DataTable dt, string parentID, string blank)
{
DataRow[] dr = dtSite.Select("PARENTID=" + parentID.ToString());
if(dr==null)
{
return;
}
for (int i=0; i<dr.Length; i++)
{
ddlSite.Items.Add(new ListItem(blank + dr["NAME"].ToString(), dr["ID"].ToString()));
this.BindData(ddlSite, dtSite, dr["ID"].ToString(), blank + " ");
}
}
使用递归来绑定。