所以我试图从另一个下拉列表中选择一个下拉列表。我测试了我正在使用的存储过程,并在输入值时获得正确的结果。我知道有很多这样的问题,但似乎没有解决我的问题。从第二个下拉列表中选择下拉菜单
protected void Page_Load(object sender, EventArgs e)
{
DataTable environments = new DataTable();
var connection = ConfigurationManager.ConnectionStrings["Connection"].ConnectionString;
using (SqlConnection conn = new SqlConnection(connection))
{
SqlDataAdapter adapter = new SqlDataAdapter("SELECT Environment FROM Environments", conn);
adapter.Fill(environments);
ddlEnvironment.Items.Insert(0, new ListItem(String.Empty, String.Empty));
ddlEnvironment.SelectedIndex = 0;
ddlEnvironment.DataSource = environments;
ddlEnvironment.DataTextField = "Environment";
ddlEnvironment.DataValueField = "Environment";
ddlEnvironment.DataBind();
SqlCommand cmd = new SqlCommand();
SqlDataAdapter adapter2 = new SqlDataAdapter();
DataTable servers = new DataTable();
cmd = new SqlCommand("sp_EnvironmentSelection", conn);
cmd.Parameters.AddWithValue("@Environment", ddlEnvironment.SelectedValue);
cmd.CommandType = System.Data.CommandType.StoredProcedure;
adapter2.SelectCommand = cmd;
adapter2.Fill(servers);
ddlServer.Items.Insert(0, new ListItem(String.Empty, String.Empty));
ddlServer.SelectedIndex = 0;
ddlServer.DataSource = servers;
ddlServer.DataTextField = "ServerName";
ddlServer.DataValueField = "ServerIP";
ddlServer.DataBind();
}
}
问题是,无论我在第一个下拉列表中选择什么,我都没有在第二个下拉列表中得到任何选择。
这里是存储过程,如果需要的话。
@Environment nvarchar(50)
AS
BEGIN
SET NOCOUNT ON
SELECT Server.ServerName, Server.ServerIP, Environments.Environment
FROM Server
INNER JOIN Environments
ON
Environments.Environment=Server.Environment
WHERE [email protected]
END
回发是否发生?当您更改第一个下拉列表时,Page_Load是否会运行? – GendoIkari
另外,你有代码处理ddlEnvironment更改事件?这是你绑定第二个下拉列表的位置,而不是在page_load – GendoIkari
我需要回发的位置?在页面加载开始或下拉更改后?我已经将第二个下拉列表添加到第一个下拉列表的已更改事件中。 – maltman