Gridview分页显示所有记录

时间:2012-09-19 21:47:51

标签: asp.net gridview

我有一个启用了分页的gridview。我还在gridview的寻呼机上有一个下拉列表,用户可以在其中选择他们想要检索的每页记录数。更改下拉列表后,将触发一个事件(如下所示),以使用每页请求的更新结果重新运行查询。这非常有效。但我确实想要在下拉列表中有一个值“All”,而我用来实现这一点的方法是禁用分页。

除了一个问题外,这一切都很出色。当用户在下拉列表中选择“全部”时,我希望在更新网格视图后仍然显示寻呼机。它没有显示,因为我关闭了分页,但有没有办法再次显示寻呼机?请参阅下面的代码以了解该活动。 (正如你所看到的那样,我在最后重新设置了寻呼机,但这没有效果)

感谢 DAMO

下拉更改事件背后的代码

void GridViewMainddl_SelectedIndexChanged(object sender, EventArgs e)
        {
            //changes page size
            if ((((DropDownList)sender).SelectedValue).ToString() == "All")
            {

                GridViewMain.AllowPaging = false;

            }
            else
            {
                GridViewMain.PageSize = int.Parse(((DropDownList)sender).SelectedValue);

            }



            //binds data source
            Result fAuditOverallStatusLatest = new Result(sConn);
            GridViewMain.DataSource = Result.getAuditOverallStatusLatest();            
            GridViewMain.PageIndex = 0;
            GridViewMain.DataBind();
            GridViewMain.AllowPaging = true;
            GridViewMain.BottomPagerRow.Visible = true;
            GridViewMain.TopPagerRow.Visible = true;
        }

DDL代码隐藏

protected void GridViewMain_RowCreated(object sender, GridViewRowEventArgs e)
        {
            if (e.Row.RowType == DataControlRowType.Pager)
            {
                DropDownList GridViewMainddl = new DropDownList();
                //adds variants of pager size
                GridViewMainddl.Items.Add("5");
                GridViewMainddl.Items.Add("10");
                GridViewMainddl.Items.Add("20");
                GridViewMainddl.Items.Add("50");
                GridViewMainddl.Items.Add("100");
                GridViewMainddl.Items.Add("200");
                GridViewMainddl.Items.Add("500");
                GridViewMainddl.Items.Add("All");
                GridViewMainddl.AutoPostBack = true;
                //selects item due to the GridView current page size
                ListItem li = GridViewMainddl.Items.FindByText(GridViewMain.PageSize.ToString());
                if (li != null)
                    GridViewMainddl.SelectedIndex = GridViewMainddl.Items.IndexOf(li);
                GridViewMainddl.SelectedIndexChanged += new EventHandler(GridViewMainddl_SelectedIndexChanged);
                //adds dropdownlist in the additional cell to the pager table
                Table pagerTable = e.Row.Cells[0].Controls[0] as Table;
                TableCell cell = new TableCell();
                cell.Style["padding-left"] = "15px";
                cell.Controls.Add(new LiteralControl("Page Size:"));
                cell.Controls.Add(GridViewMainddl);
                pagerTable.Rows[0].Cells.Add(cell);
                //add current Page of total page count
                TableCell cellPageNumber = new TableCell();
                cellPageNumber.Style["padding-left"] = "15px";
                cellPageNumber.Controls.Add(new LiteralControl("Page " + (GridViewMain.PageIndex + 1) + " of " + GridViewMain.PageCount));
                pagerTable.Rows[0].Cells.Add(cellPageNumber);

            }
        }

1 个答案:

答案 0 :(得分:1)

将其放入Page_Init

GridViewMain.PreRender += new EventHandler(GridViewMain_PreRender);

然后在Page班级的其他地方:

void GridViewMain_PreRender(object sender, EventArgs e)
{
    var pagerRow = (sender as GridView).BottomPagerRow;
    if (pagerRow != null)
    {
        pagerRow.Visible = true;
    }
}

然后是你的下拉事件:

void GridViewMainddl_SelectedIndexChanged(object sender, EventArgs e)
{
    MyServices fServices = new FAServices(sConn);
    Result fAuditOverallStatusLatest = new Result(sConn);
    var data = Result.getAuditOverallStatusLatest();

    //changes page size
    if ((((DropDownList)sender).SelectedValue).ToString() == "All")
    {
        GridViewMain.PageSize = data.Count();
    }
    else
    {
        GridViewMain.PageSize = int.Parse(((DropDownList)sender).SelectedValue);
    }

    //binds data source
    GridViewMain.DataSource = data;            
    GridViewMain.PageIndex = 0;
    GridViewMain.DataBind();
    GridViewMain.AllowPaging = true;
}

在PreRender活动中,您必须复制顶部寻呼机的代码。

编辑:要选择All,请在GridViewMain_RowCreated中进行此更改:

if (li != null)
{
    GridViewMainddl.SelectedIndex = GridViewMainddl.Items.IndexOf(li);
}
else
{
    GridViewMainddl.SelectedIndex = GridViewMainddl.Items.Count - 1;
}