分页后,GridVIew在搜索时不显示所有数据

时间:2016-02-24 19:28:28

标签: asp.net gridview page-index-changed

我的GridView在第二页上执行搜索后无法显示正确的数据。

填充GridView并使用PageIndexChanging方法导航到第二页后,应用搜索过滤器后,GridView不会刷新。它保留在同一页面上,但必须重新加载。

我的搜索调用以下方法:

private void PopulatePeople()
{
    lblAddError.Text = String.Empty;
    if (ViewState["_message"] != null)
    {
        lblAddError.Visible = true;
        lblAddError.Text = ViewState["_message"].ToString();
    }
    ViewState["_message"] = null;

    int portfolio = int.Parse(ddlPortfolio.SelectedItem.Value);
    ViewState["_portfolioID"] = portfolio;
    string year = ddlYear.SelectedItem.Text;
    string month = ddlMonth.SelectedItem.Text;

    if (ViewState[_vsPeopleList] != null)
    {
        ViewState[_vsPeopleList] = null;
    }

    List<PeopleManagement> list = PeopleManagement.GetPeople(portfolio, year, month);

    ViewState[_vsPeopleList] = list;

    if(list.Count == 0)
    {
        gvPeople.Visible = false;
        lblAddError.Visible = true;
        lblAddError.Text = "No data available for current selection";
    }
    else
    {
        gvPeople.Visible = true;
        gvPeople.DataSource = list;
        gvPeople.DataBind();
    }
}

此方法根据搜索过滤器显示数据。

我生成了2个页面。第1页有10条记录,第2页有1条记录。

当分页到第二页并再次单击搜索而不更改任何搜索过滤器时,GridView仍会在第二页上显示1条记录。但是,它应该显示第一页有10条记录。看起来,GridView不会回到第1页。

这是我的PageIndexChanging方法:

protected void gvPeople_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
    lblAddError.Text = String.Empty;
    List<PeopleManagement> list = (List<PeopleManagement>)ViewState[_vsPeopleList];
    gvPeople.DataSource = list;
    gvPeople.PageIndex = e.NewPageIndex;
    gvPeople.DataBind();
}

我不知道出了什么问题。尝试调试已经有一段时间了。 当第一次搜索和更改页面索引时,列表具有相同的记录数量。应该工作得很好......

1 个答案:

答案 0 :(得分:0)

基因,

这是因为PageIndex属性设置为您导航到的新页面。只需在搜索功能中将PageIndex重置为零。