使用分页过滤LINQ结果在ASP.NET Web窗体中

时间:2012-07-16 12:24:44

标签: c# asp.net linq linq-to-sql webforms

我正在尝试过滤GridView的内容,但是我在这个过程中得到了一些关闭行为:

asp页面的内容如下所示:

<form id="form1" runat="server">

<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<asp:Button ID="button1" runat="server" onclick="button1_Click" Text="Submit" />
<asp:GridView ID="GridView1" AllowPaging="true" PageSize="8"
AutoGenerateColumns="false" runat="server"
OnPageIndexChanging="GridView1_PageIndexChanging">

<Columns>
  <asp:BoundField HeaderText="ID" DataField="ID" />
  <asp:BoundField HeaderText="Client Name" DataField="Client_Name" />
  <asp:BoundField HeaderText="Project" DataField="Project_Name" />
  <asp:BoundField HeaderText="Uploaded By" DataField="Uploaded_By" />
</Columns>

</asp:GridView>
</form>

文件背后的代码:

public partial class Sample1 : System.Web.UI.Page
{
  protected void Page_Load(object sender, EventArgs e)
  {
    if (!this.Page.IsPostBack)
    {
        SourceDataContext db = new SourceDataContext();

        GridView1.DataSource = from q in db.Cust
                               orderby q.ID
                               select q;
        GridView1.DataBind();
    }
}

protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
    GridView1.PageIndex = e.NewPageIndex;
}

protected void button1_Click(object sender, EventArgs e)
{
    string client = TextBox1.Text;

    SourceDataContext db = new SourceDataContext();

    GridView1.DataSource = from q in db.Cust
                           where q.Client_Name == client
                           orderby q.ID
                           select q;
    GridView1.DataBind();

    //reset page index to 0
    GridView1.PageIndex = 0;
}
}

过滤部分有效,但分页不起作用。此外,分页需要点击两次页面才能被选中。

感谢。

1 个答案:

答案 0 :(得分:0)

试试吧。 将此代码保存在函数中,将其命名为BindGrid

private void BindGrid()
{
 SourceDataContext db = new SourceDataContext();

    GridView1.DataSource = from q in db.Cust
                           orderby q.ID
                           select q;
    GridView1.DataBind();
}
// Create this method in your code behind

并在分配新索引

后在GridView1_PageIndexChanging中调用它
protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
    GridView1.PageIndex = e.NewPageIndex;
    BindGrid();
}