微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 当DataSource不返回完整的结果集时,手动设置GridView的PageCount?

我试图找出ASP.NET的GridView分页机制,所以我可以使用框架的本机功能,而不是我公司的自制的手工分页例程,需要大量的工作来实现.

我已经弄清楚除了GridView的PageCount属性如何使用我们的Web服务之外的所有内容.目前,我们的网络服务返回总记录数如下:

public object[] GetStuffMethod(int pageNum,int recordsPerPage,out int totalRecords)

这对GridView很好,但是我发现的文档说,GrideView的PageCount属性是从DataSource中的总记录生成的.是否真的没有办法设置PageCount基于除了返回所有记录之外的其他东西?

数据源中可能有成千上万的记录,所以我宁可不选择所有这些记录,只是为了使GridView的页面计数工作.我可能会忽略GridView的页数,并自行计算,但是如果框架有一个方法可以做到这一点,我宁愿使用它.

解决方法

我强烈建议您去ObjectDataSource路由.

如果你不熟悉这种方法,这里是基础:

1)而不是在后面的代码中手动设置grid.DataSource属性,您可以向页面添加一个额外的元素.您将网格的DataSourceID设置为ObjectDataSource的ID.

2)这是你真正掌握的地方.您创建一个新类并给它两个函数“SelectRows()”和“GetCount()”.您可以将自己的逻辑放在两个功能中,并优化您的心脏的内容.如果您需要使用Web服务,请随意使用Web服务,但在此方法下,您可以调用一个返回行以返回计数.

3)使用ObjectDataSource的属性编辑器将其连接到您的类并启用分页.你已经设置好了

我强烈建议您查看The Code Project’s Example of using ObjectDataSource and GridView,因为这显然是支持您想要的方式.

祝你好运!

原文地址:https://www.jb51.cc/csharp/96702.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐