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