Получение значения 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(), так далее.

Надеюсь, что это может помочь.

Другие вопросы по тегам