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

前端之家收集整理的这篇文章主要介绍了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,因为这显然是支持您想要的方式.

祝你好运!

猜你在找的C#相关文章