Пейджинговая проблема с GridView - PullRequest
0 голосов
/ 23 июля 2011

У меня есть веб-страница asp.net с GridView

<asp:GridView ID="grid_view" runat="server" AllowPaging="True" 
    AutoGenerateColumns="False" BackColor="White" BorderColor="#999999" 
    BorderStyle="Solid" BorderWidth="1px" CellPadding="3" ForeColor="Black" 
    GridLines="Vertical">
    <FooterStyle BackColor="#CCCCCC" />
    <Columns>
        <asp:BoundField DataField="adc" HeaderText="Posa No." />
        <asp:BoundField DataField="cde" HeaderText="Unit" />
        <asp:BoundField DataField="efg" HeaderText="User" />
        <asp:BoundField DataField="hj" HeaderText="Posa Date" />
    </Columns>
    <PagerStyle BackColor="#999999" ForeColor="Black" HorizontalAlign="Center" />
    <SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
    <HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" /> 
    <AlternatingRowStyle BackColor="#CCCCCC" />
</asp:GridView>

, и мой код:

protected void Page_Load(object sender, EventArgs e)
{
  con = new SqlConnection(ConfigurationManager.AppSettings["Connection"]);
  gridfil();
}


public void gridfil()
{
  con.Open();
  cmd = new SqlCommand("select a,b,c from xyz where approved='sss'", con);
  SqlDataAdapter da = new SqlDataAdapter(cmd);
  SqlCommandBuilder cb = new SqlCommandBuilder(da);
  DataSet ds = new DataSet();
  da.Fill(ds);
  grid_view.DataSource = ds;
  grid_view.DataBind();
  //rd.Close();
  da.Dispose();
  cmd.Dispose();
  con.Close();
}

protected void grid_view_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
  grid_view.PageIndex = e.NewPageIndex;
  gridfil();
}

Моя проблема заключается в том, что представление сетки было отображено, но индексация страницы не выполненаработает ... У кого-нибудь есть предложения?

1 Ответ

0 голосов
/ 23 июля 2011

Поместите код загрузки вашей страницы под !IsPostBack()

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        con = new SqlConnection(ConfigurationManager.AppSettings["Connection"]);
        gridfil();
    }
}

Причина: Каждый раз, когда вы нажимаете на номер страницы и хотите просмотреть другую страницу, страница будет отправляться назад, а ваш page load event срабатывает до grid_view_PageIndexChanging, и он перепривязывает вид сетки, и ваше событие будет потеряно, и оно не будет запускать событие PageIndexChanging.

Во-вторых, измените это и просмотрите комментарии

protected void grid_view_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
  gridfil(); // First bind the gridview 
  grid_view.PageIndex = e.NewPageIndex; // then change the page Index
}
...