gpt4 book ai didi

asp.net - 使用 DataPager 而不检索每个请求的所有行

转载 作者:行者123 更新时间:2023-12-05 00:44:02 27 4
gpt4 key购买 nike

我有一个 ListView,我正在将数据绑定(bind)到一组对象,如下所示:

int total;
List<Client> clientList =
clientData.GetClients(criteria, pageNum, pageSize, out total);
uxClientList.DataSource = clientList;
uxClientList.DataBind();

其中 pageNum、pageSize 和 total 参数便于在数据访问层进行分页。到现在为止还挺好。

现在我可以在页面上抛出一个 DataPager,将它指向 ListView 并获得一个不错的分页 UX。 There's a little more to it when you're binding programmatically instead of declaratively with a data source control ,但这里的问题是 DataPager 期望每次都检索整个结果集,它应该从中计算分页,因此它会将返回的单页结果视为可用记录总数,并呈现为好像只有一个可用结果页面。换句话说,如果我们切换到 GetClients 的非分页版本,上述场景可以很好地使用 DataPager:
List<Client> clientList = clientData.GetClients(criteria);
uxClientList.DataSource = clientList;
uxClientList.DataBind();

显然,由于我们的数据访问层足以为我们提供一次检索页面的方法,因此这比每次都检索所有记录更可取。如果我们可以明确地通知 DataPager 可用记录总数,这样它仍然可以自动创建分页输出,但一次只需要一页就可以了。

我还没有找到一个简单的方法来做到这一点,我也没有在搜索中找到任何东西。诚然,我目前对 DataPager 的实现没有深入的了解,所以希望我忽略了一些东西。

最佳答案

查看 ListViewPagedDataSource 及其 AllowServerPaging属性(property),我认为 可能成为你正在寻找的东西..

关于asp.net - 使用 DataPager 而不检索每个请求的所有行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/429707/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com