asp.net - GridView分页,无法获取正确的Datakey值

标签 asp.net gridview paging datakey

GridView

<asp:GridView ID="GridView1" runat="server" AllowPaging="True" 
    AllowSorting="True" PagerSettings-Position="TopAndBottom"
    PagerSettings-Mode="Numeric" PageSize="40" CellPadding="4" DataSourceID="dsEquipmentGridView"
    ForeColor="#333333" GridLines="Horizontal" Style="font-size: x-small" AutoGenerateColumns="False"
    DataKeyNames="IREF" OnRowEditing="GridView1_RowEditing" OnRowUpdated="GridView1_RowUpdated"
    OnSorted="GridView1_Sorted" OnSorting="GridView1_Sorting" OnPageIndexChanged="GridView1_PageIndexChanged1"
    OnPageIndexChanging="GridView1_PageIndexChanging" OnSelectedIndexChanged="GridView1_SelectedIndexChanged"
    OnSelectedIndexChanging="GridView1_SelectedIndexChanging" OnRowCommand="GridView1_RowCommand"
    BorderColor="Black" BorderStyle="Solid" BorderWidth="1px" 
    OnRowCancelingEdit="GridView1_RowCancelingEdit" onload="GridView1_Load" 
    ondatabound="GridView1_DataBound">
    <PagerSettings Position="TopAndBottom" />
    <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
    <Columns>
 <asp:CommandField ShowDeleteButton="False" ShowSelectButton="true" EditText="QuickEdit"
     HeaderText="Manage" SelectText="Manage" />

对于加载的第一页,如果我单击命令字段,它会显示正确的 DataKey 值。

但是,如果我更改到下一页结果,在选择记录时,相应的值不正确。似乎保留了上一页的信息。我该如何克服这个问题?

编辑:

在 GridView1_SelectedIndexChanged 方法中,我使用了以下内容:

    // Determine the index of the selected row.
    int index = GridView1.SelectedIndex;

    // Display the primary key value of the selected row.
    HttpContext.Current.Response.Write("The primary key value of the selected row is " + GridView1.DataKeys[index].Value.ToString() + ".<br>");

    GridViewRow row = GridView1.Rows[index];

    int rowindex = row.RowIndex;
    HttpContext.Current.Response.Write("rowindex-> " + rowindex.ToString() + "<br>");

    int ID = (int)GridView1.DataKeys[row.DataItemIndex - (GridView1.PageIndex * GridView1.PageSize)].Value;

    HttpContext.Current.Response.Write("row.DataItemIndex" + ID.ToString()+"<br>");

    int Userid = Convert.ToInt32(GridView1.DataKeys[index].Value);

    HttpContext.Current.Response.Write("Userid" + Userid.ToString() + "<br>");

分页后无法获取正确的值。

最佳答案

使用分页时,我们可以获得准确的行索引(在gridview中从0到totalrows计数) 并且在获取datakey时,我们需要传递当前页面的行索引。

使用下面的行获取当前页面索引并获取数据 key :

// Get the correct row index since there is paging
int idx = gridViewRow.DataItemIndex - TestGridView.PageIndex * TestGridView.PageSize;

关于asp.net - GridView分页,无法获取正确的Datakey值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3413277/

相关文章:

c# - ReportViewer 2010 不刷新异步回发

c# - 如何拉取 asp :button inside an asp:listview for use with jQuery? 的 clientID

c# - 使用 DI 时无法解析服务

asp.net - 无法确定 GridView 中复选框的状态

gridview - 在 Yii2 gridview 中禁用分页

javascript - 刷新 KendoUI 网格 - 寻呼机损坏

memory - 多级页表如何节省内存空间?

c# - ASP.NET - 转换本地化数字

Android 从 GridView 中的 EditText 获取文本

c# - 使用 LINQ 对对象进行分页