我有一個Dropdownlist
和一個數據列表中的按鈕。我從dropdownlist中選擇項目的數量,然後將其傳遞給按鈕事件以將其發送到數據庫。如何在事件之間傳遞值?
但我無法這樣做。問題是變量selectedValue
只在dditem_change
內被賦值,儘管我已經在全局聲明它。如何在DataList1_ItemCommand(object source, DataListCommandEventArgs e)
中訪問其值。
下面是下拉列表改變
public void dditem_change(object sender, EventArgs e)
{
var ddlList = (DropDownList)sender;
selectedValue = ((DropDownList)ddlList.NamingContainer.FindControl("drplist")).SelectedValue;
}
代碼這是公共無效DataList1_ItemCommand
public void DataList1_ItemCommand(object source, DataListCommandEventArgs e)
{
if(e.CommandName == "Add")
{
if (Session["user"] == null)
{
Response.Write("<script>alert('Login First!!!');</script>");
}
else
{
string[] ar = e.CommandArgument.ToString().Split(',');
SqlConnection con = new SqlConnection();
con.ConnectionString = "Data Source=DTPXP-77A;Initial Catalog=practice;Integrated Security=true";
con.Open();
SqlCommand cmd = new SqlCommand("insert into cart values(@username,@prodname,@price,@stock)", con);
cmd.Parameters.Add("@username", SqlDbType.VarChar);
cmd.Parameters.Add("@prodname", SqlDbType.VarChar);
cmd.Parameters.Add("@price", SqlDbType.Int);
cmd.Parameters.Add("@stock", SqlDbType.Int);
cmd.Parameters["@username"].Value = Session["user"].ToString();
cmd.Parameters["@prodname"].Value = ar[0].ToString();
cmd.Parameters["@price"].Value = int.Parse(ar[1]);
cmd.Parameters["@stock"].Value = //selectedValue NOT ACCESSIBLE//
cmd.ExecuteNonQuery();
Response.Write("<script>alert('Successfully Added');</script>");
}
}
}
你可以在DataList1_ItemCommand中使用ddlList.SelectedValue嗎? – appcoder
你能說明它是如何聲明的以及在頁面類的上下文中的位置嗎? – Steve
不,我不能訪問ddllist.SelectedValue裏面DataList1_ItemCommand –