Кнопка «Просмотр сетки» Передача данных по нажатию - PullRequest
2 голосов
/ 16 июня 2010

Я довольно новичок в C # и asp.net, поэтому извиняюсь, если это действительно глупый вопрос.

Я использую сетку для отображения количества записей из базы данных.

В каждой строке есть кнопка редактирования. Когда кнопка нажата, я хочу, чтобы идентификатор был передан функции в моем файле .cs. Как связать rowID с полем Button?

Я устал использовать гиперссылку, но это, похоже, не работает, потому что я отправляю сообщение на ту же страницу, на которой уже есть постоянный адрес в URL.

asp.net

<asp:GridView ID="gvAddresses" runat="server" onrowcommand="Edit_Row">
    <Columns>
        <asp:ButtonField runat="server" ButtonType="Button" Text="Edit">
    </Columns>
</asp:GridView>

с #

        int ImplantID = Convert.ToInt32(Request.QueryString["ImplantID"]);
        Session.Add("ImplantID", ImplantID);

        List<GetImplantDetails> DataObject = ImplantDetails(ImplantID);

        System.Data.DataSet DSImplant = new DataSet();
        System.Data.DataTable DTImplant = new DataTable("Implant");

        DSImplant.Tables.Add(DTImplant);

        DataColumn ColPostCode = new DataColumn();
        ColPostCode.ColumnName = "PostCode";
        ColPostCode.DataType = typeof(string);
        DTImplant.Columns.Add(ColPostCode);

        DataColumn ColConsigneeName = new DataColumn();
        ColConsigneeName.ColumnName = "Consignee Name";
        ColConsigneeName.DataType = typeof(string);
        DTImplant.Columns.Add(ColConsigneeName);

        DataColumn ColIsPrimaryAddress = new DataColumn();
        ColIsPrimaryAddress.ColumnName = "Primary";
        ColIsPrimaryAddress.DataType = typeof(int);
        DTImplant.Columns.Add(ColIsPrimaryAddress);

        DataColumn ColImplantCustomerDetailsID = new DataColumn();
        ColImplantCustomerDetailsID.ColumnName = "Implant ID";
        ColImplantCustomerDetailsID.DataType = typeof(int);
        DTImplant.Columns.Add(ColImplantCustomerDetailsID); 

        foreach (GetImplantDetails Object in DataObject)
        {

            DataRow DRImplant = DTImplant.NewRow();
            DRImplant["PostCode"] = Object.GetPostCode();
            DRImplant["Consignee Name"] = Object.GetConsigneeName();
            DRImplant["Primary"] = Object.GetIsPrimaryAddress();
            DRImplant["Implant ID"] = Object.GeTImplantCustomerDetailsID();
            DTImplant.Rows.Add(DRImplant); <--- this is what I need to be added to the button

        }

        gvAddresses.DataSource = DTImplant;
        gvAddresses.DataBind(); 

1 Ответ

2 голосов
/ 16 июня 2010

В вашем методе Edit_Row вы можете получить доступ к индексу строки, которую вы редактируете, например:

int rowIndex = (int)e.CommandArgument;

Получив доступ к строке, вы можете получить все нужные значения:

GridViewRow row = gvTest.Rows[rowIndex];
int implantId = Int32.Parse(string row.Cells[3].Text);

Кроме того, вы также можете добавить свойство DataKeyNames="Implant ID" в GridView и получить доступ к идентификатору следующим образом:

int implantId = Int32.Parse(gvTest.DataKeys[rowIndex]["Implant ID"].ToString());
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...