更新gridview而不重建整个页面

时间:2013-04-12 03:31:23

标签: gridview postback

我有一个复杂的页面,其中放置了面板和许多控件。该页面包括一组过滤器和gridview。通过选择不同的过滤器,我会为gridview收到不同数量的项目。这一切都有效但更新速度非常慢,也就是当我更改过滤器并按下我的更新按钮时。我需要找到一个解决方案来加速这个动作!所以这里有一个问题:是否可以仅更新gridview的数据源而无需重建整个页面。我们的想法是尽快更新网格视图;网格中可能有超过10,000个项目。 感谢

1 个答案:

答案 0 :(得分:6)

我建议将GridView和过滤器控件放到页面上的UpdatePanel中:

<asp:UpdatePanel runat="server" id="upData">
    <ContentTemplate>
        <div id="filterControls">
            <asp:TextBox runat="server" id="txtFilter"></asp:TextBox>
            <asp:Button runat="server" id="btnFilter" Text="Filter" />
        </div>

        <asp:GridView runat="server" id="gvItems">
            <EmptyDataTemplate>No results to display</EmptyDataTemplate>
        </asp:GridView>
    </ContentTemplate>
</asp:UpdatePanel>

完成后,您可以再次获取数据。我没有指定vb和c#的代码:

C#

protected void Page_Load(object sender, EventArgs e)
{
    // get the data initially on page load
    if (!IsPostBack)
    {
        loadDataGrid();
    }
}

protected void btnFilter_Click(object sender, EventArgs e)
{
    loadDataGrid();
}

private void loadDataGrid()
{
    // call a procedure to get the data. This is what I use:
    // execDB(string commandText, string commandType, List<SqlParameter> args, bool newConnection);
    using (Database db = new Database())
    {
        List<SqlParameter> args = new List<SqlParameter>();
        args.Add(new SqlParameter("@filter1", SqlDbType.VarChar));
        args(args.Count - 1).Value = txtFilter1.Text;

        DataTable dt = db.execDB("Users_GetAll", "SP", args.ToArray(), false);

        if (dt.Rows.Count > 0)
        {
            gvItems.DataSource = dt;
            gvItems.DataBind();
        }
    }
}

VB

Protected Sub Page_Load(sender As Object, e As EventArgs)
    ' get the data initially on page load
    If Not IsPostBack Then
        loadDataGrid()
    End If
End Sub

Protected Sub btnFilter_Click(sender As Object, e As EventArgs)
    loadDataGrid()
End Sub

Private Sub loadDataGrid()
    ' call a procedure to get the data. This is what I use:
    ' execDB(string commandText, string commandType, List<SqlParameter> args, bool newConnection);
    Using db As New Database()
        Dim args As New List(Of SqlParameter)()
        args.Add(New SqlParameter("@filter1", SqlDbType.VarChar))
        args(args.Count - 1).Value = txtFilter1.Text

        Dim dt As DataTable = db.execDB("Users_GetAll", "SP", args.ToArray(), False)

        If dt.Rows.Count > 0 Then
            gvItems.DataSource = dt
            gvItems.DataBind()
        End If
    End Using
End Sub

这基本上会导致过滤器按钮更新GridView,只获取它所需的数据,因为它位于UpdatePanel中,它还可以避免回发整个页面,这应该可以提高整个页面的速度。

希望这有帮助!