加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 17:42:19 所属栏目:百科 来源:网络整理
导读:我试图找出ASP.NET的GridView分页机制,所以我可以使用框架的本机功能,而不是我公司的自制的手工分页例程,需要大量的工作来实现. 我已经弄清楚除了GridView的PageCount属性如何使用我们的Web服务之外的所有内容.目前,我们的网络服务返回总记录数如下: public
我试图找出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,因为这显然是支持您想要的方式.

祝你好运!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读