Es scheint ein sehr einfaches Problem, aber es hat meinen Tag getötet. Ich habe eine update-fähige Gridview und habe eine Dropdown-Liste in den Bearbeitungsmodus einer der Spalten eingefügt. Die Elemente in der DDL sind statisch festgelegt. ABER der ausgewählte Gegenstand bleibt immer der erste Gegenstand. Wie kann ich das beheben?Dropdown-Liste in Gridview, ausgewählter Wert ändert sich nicht
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
string userID = ((Label)GridView1.Rows[e.RowIndex].FindControl("lbluserID")).Text;
string role = ((DropDownList)GridView1.Rows[e.RowIndex].FindControl("DropDownList1")).SelectedValue;
SqlCommand cmd = new SqlCommand();
cmd.Connection = DBSettings.sqlConn;
cmd.CommandText = "Update tbl_users set [email protected] , pending='false' ,approved='true' , declined='false' where [email protected]";
cmd.Parameters.AddWithValue("@role", role);
cmd.Parameters.AddWithValue("@ID", userID);
cmd.ExecuteNonQuery();
GridView1.EditIndex = -1;
gridFill();
}
hier ist die aspx des Gridview (nur der DDL Teil):
<asp:TemplateField HeaderText="Role">
<EditItemTemplate>
<asp:DropDownList ID="DropDownList1" runat="server" AutoPostBack="True">
<asp:ListItem Value="">--Select--</asp:ListItem>
<asp:ListItem Value="Admin" Text="Admin"></asp:ListItem>
<asp:ListItem Value="Editor" Text="Editor"></asp:ListItem>
<asp:ListItem Value="Viewer" Text="Viewer"></asp:ListItem>
</asp:DropDownList>
</EditItemTemplate>
<ItemTemplate>
<asp:Label ID="Label1" runat="server" Text="pending"></asp:Label>
</ItemTemplate>
</asp:TemplateField>