我有一个 ListView,我正在将数据绑定到一组对象,如下所示:
int total;
List<Client> clientList =
clientData.GetClients(criteria, pageNum, pageSize, out total);
uxClientList.DataSource = clientList;
uxClientList.DataBind();
其中 pageNum、pageSize 和 total 参数便于在数据访问层进行分页。到现在为止还挺好。
现在我可以在页面上抛出一个 DataPager,将它指向 ListView 并获得一个不错的分页 UX。当您以编程方式而不是以声明方式与数据源控件绑定时,还有更多内容,但这里的问题是 DataPager 期望每次都检索整个结果集,它应该从中计算分页,所以它看到单页结果作为可用记录总数返回,并呈现为好像只有一页可用结果一样。换句话说,如果我们切换到 GetClients 的非分页版本,上述场景可以很好地使用 DataPager:
List<Client> clientList = clientData.GetClients(criteria);
uxClientList.DataSource = clientList;
uxClientList.DataBind();
显然,由于我们的数据访问层足以为我们提供一次检索页面的方法,因此这比每次都检索所有记录更可取。如果我们可以明确地通知 DataPager 可用记录总数,这样它仍然可以自动创建分页输出,但一次只需要一页就可以了。
我还没有找到一个简单的方法来做到这一点,我也没有在搜索中找到任何东西。诚然,我目前对 DataPager 的实现没有深入的了解,所以希望我忽略了一些东西。