我在页面上有一个DataGridView
。当我打电话给那个页面时,整个列表来了我决定将分页添加到GridView
。
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="id" OnRowDeleting="GridView1_Del" OnSelectedIndexChanging="GridView1_Sel" OnPageIndexChanging="GridView1_PageIndexChanging">
<Columns>
<asp:BoundField DataField="id" HeaderText="Id" SortExpression="id" Visible="false" />
<asp:BoundField DataField="name" HeaderText="Name" SortExpression="name" />
<asp:BoundField DataField="author" HeaderText="Author" SortExpression="author" />
<asp:BoundField DataField="active" HeaderText="Active" SortExpression="active" />
<asp:CommandField HeaderText="Delete" SelectText="Delete" ShowDeleteButton="True" ButtonType="Button" />
</Columns>
</asp:GridView>
//Page_Load()
gridFill();
GridView1.AllowPaging = true;
GridView1.PageSize = 10;
gridFill()
方法填充GridView
。
public void gridFill()
{
conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:/inetpub/example.com/db/db.mdb");
sql = "SELECT id, name, author, active, FROM [table]";
dt = new DataTable();
try
{
if (conn.State != ConnectionState.Open) conn.Open();
comm= new OleDbCommand(sql, conn);
da= new OleDbDataAdapter(comm);
da.Fill(dt);
if (dt.Rows.Count > 0)
{
GridView1.DataSource = dt;
GridView1.DataBind();
}
}
catch (System.Data.OleDb.OleDbException ex)
{
string msg = "Error: ";
msg += ex.Message;
throw new Exception(msg);
}
finally
{
conn.Close();
}
}
当我调用页面时,它仍会立即获取所有行。此外,如果我点击11或更晚(因为我将分页限制为10行)删除行我得到索引错误。
所以我添加了另一个标记为'Refresh'的Button
,再次调用gridFill()方法。然后分页变得有效。
GridView第一次不进行分页的原因是什么?
答案 0 :(得分:1)
如果我改变了行的顺序
//Page_Load()
gridFill();
GridView1.AllowPaging = true;
GridView1.PageSize = 10;
到
//Page_Load()
GridView1.AllowPaging = true;
GridView1.PageSize = 10;
gridFill();
它有效。我无法相信