在 ItemTemplate ASP.NET C# 中级联 DropDownList
Cascading DropDownList within an ItemTemplate ASP.NET C#
我正在尝试在我的 ASP.NET C# Web 应用程序中创建级联下拉列表。应该发生的是,当第一个下拉列表选择的索引发生更改时,它会调用下面的代码,然后用新值填充第二个下拉列表。问题是当我尝试填充第二个下拉列表时,两个下拉列表都显示为空。当我搜索它们时,似乎没有找到控件。它们在页面加载时使用 Repeater 的 ItemTemplateField 中的正确信息进行填充。如何在 Repeater 中没有 Javascript 且只有 C# 的级联下拉列表?任何帮助深表感谢。下面的代码在 ddl2.Items.Clear();
行崩溃
protected void ddlCountry_SelectedIndexChanged(object sender, EventArgs e)
{
DropDownList ddl = (DropDownList) NameRepeater.FindControl("ddlCountry");
DropDownList ddl2 = (DropDownList) NameRepeater.FindControl("ddlState");
ddl2.Items.Clear();
using(SqlConnection conn = new SqlConnection(connString))
{
using(SqlCommand cmd = new SqlCommand())
{
cmd.CommandText = "SELECT State, StateID FROM States WHERE CountryID = " + ddl.SelectedValue;
cmd.Connection = conn;
conn.Open();
using(SqlDataReader sdr = cmd.ExecuteReader())
{
while (sdr.Read())
{
ListItem _listStates = new ListItem();
_listStates.Text = sdr["State"].ToString();
_listStates.Value = sdr["StateID"].ToString();
ddl2.Items.Add(_listStates);
}
}
}
}
ddl2.AppendDataBoundItems = true;
ddl2.Items.Insert(0, new ListItem("Select a State", "-1"));
ddl2.SelectedIndex = -1;
}
别忘了调用 DataBind()
,填充下拉列表后需要它:
ddl2.DataBind();
编辑:
DropDownList ddl = (DropDownList)NameRepeater.Items[0].FindControl("ddlCountry");
DropDownList ddl2 = (DropDownList)NameRepeater.Items[0].FindControl("ddlState");
我正在尝试在我的 ASP.NET C# Web 应用程序中创建级联下拉列表。应该发生的是,当第一个下拉列表选择的索引发生更改时,它会调用下面的代码,然后用新值填充第二个下拉列表。问题是当我尝试填充第二个下拉列表时,两个下拉列表都显示为空。当我搜索它们时,似乎没有找到控件。它们在页面加载时使用 Repeater 的 ItemTemplateField 中的正确信息进行填充。如何在 Repeater 中没有 Javascript 且只有 C# 的级联下拉列表?任何帮助深表感谢。下面的代码在 ddl2.Items.Clear();
protected void ddlCountry_SelectedIndexChanged(object sender, EventArgs e)
{
DropDownList ddl = (DropDownList) NameRepeater.FindControl("ddlCountry");
DropDownList ddl2 = (DropDownList) NameRepeater.FindControl("ddlState");
ddl2.Items.Clear();
using(SqlConnection conn = new SqlConnection(connString))
{
using(SqlCommand cmd = new SqlCommand())
{
cmd.CommandText = "SELECT State, StateID FROM States WHERE CountryID = " + ddl.SelectedValue;
cmd.Connection = conn;
conn.Open();
using(SqlDataReader sdr = cmd.ExecuteReader())
{
while (sdr.Read())
{
ListItem _listStates = new ListItem();
_listStates.Text = sdr["State"].ToString();
_listStates.Value = sdr["StateID"].ToString();
ddl2.Items.Add(_listStates);
}
}
}
}
ddl2.AppendDataBoundItems = true;
ddl2.Items.Insert(0, new ListItem("Select a State", "-1"));
ddl2.SelectedIndex = -1;
}
别忘了调用 DataBind()
,填充下拉列表后需要它:
ddl2.DataBind();
编辑:
DropDownList ddl = (DropDownList)NameRepeater.Items[0].FindControl("ddlCountry");
DropDownList ddl2 = (DropDownList)NameRepeater.Items[0].FindControl("ddlState");