Получение значения DataKey в командном событии ASP.NET GridView on Button
Gridview настроен:
<asp:GridView ID="gvApptList" runat="server" CssClass="fullwidth" AutoGenerateColumns="False" DataKeyNames="AppointmentID">
<Columns>
<asp:BoundField DataField="Designer" HeaderText="Designer" SortExpression="Designer" />
<asp:BoundField DataField="AppointmentDTM" HeaderText="Appointment Date" SortExpression="AppointmentDTM" DataFormatString="{0:MM-dd-yyyy hh:mm tt}" />
<asp:BoundField DataField="Status" HeaderText="Status" SortExpression="Status" />
<asp:BoundField DataField="Disposition" HeaderText="Disposition" SortExpression="Disposition" />
<asp:BoundField DataField="AppointmentNotes" HeaderText="Appointment Notes" SortExpression="AppointmentNotes" />
<asp:ButtonField ButtonType="Button" CommandName="viewAppointment" Text="View" />
</Columns>
</asp:GridView>
Когда я нажимаю кнопку "Просмотр", запускается gvApptList_RowCommand. Код для этого:
If e.CommandName = "viewAppointment" Then
Dim tApptID As Long
gvApptList.SelectedIndex = e.CommandArgument
If IsNumeric(gvApptList.DataKeys(e.CommandArgument).Value) Then
tApptID = gvApptList.SelectedDataKey.Value
Else
Exit Sub
End If
tbAppointmentID.Text = tApptID
DisplayInfo()
End If
GvApptList.DataKeys(e.CommandArgument). Значение всегда возвращается как ничто. Что мне здесь не хватает? У меня есть точный код продажи, работающий на других страницах.
1 ответ
Соответствующий вашей задаче правильный синтаксис с использованием DataKeys
в ASP.NET GridView
управление показано ниже (повторно: http://www.codeproject.com/Tips/225352/Nesting-GridView-control-in-ASP-NET, написанный на C#):
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
// get data key from selected row
s.SelectParameters[0].DefaultValue =Convert.ToString(((GridView)sender).DataKeys[e.Row.RowIndex].Values["AppointmentID "]);
}
}
Вы должны получить ссылку на Row
в соответствии с командой Button
щелкнул, затем извлеките DataKeys
значение от этого Row
, Кроме того, убедитесь, что в основе DataSource
содержит AppointmentID
поле в своем запросе SELECT.
В вашем случае это может выглядеть следующим образом (см. Листинг 2).
Листинг 2
protected void ViewButton_OnClick(object sender, EventArgs e)
{
Button btn = sender as Button;
GridViewRow row = btn.NamingContainer as GridViewRow;
string strID = gvApptList.DataKeys[row.RowIndex].Values["AppointmentID"].ToString();
int intID;
if (String.IsNotNullOrEmpty(strID)
{
intID = int.Parse(strID);
}
}
или вы можете использовать TryParse()
, Convert()
, так далее.
Надеюсь, что это может помочь.