gpt4 book ai didi

asp.net - 如何将 DataPager 与服务器端分页结合使用?

转载 作者:行者123 更新时间:2023-12-02 11:33:03 25 4
gpt4 key购买 nike

我正在尝试使用 DataPager 进行服务器端分页。这是我的代码

<asp:DataPager ID="pgrFooBars" PagedControlID="lvFooBars" 
QueryStringField="page" runat="server" >
<Fields>
<asp:NumericPagerField />
</Fields>
</asp:DataPager>

隐藏代码

protected void Page_Load(object sender, EventArgs e)
{
ConfigureBlogPostListView();
}

private void ConfigureBlogPostListView()
{
int pageNum;
int.TryParse(Request.Params["page"], out pageNum);
int pageSize = 20;

PagedList<IFooBar> FooBars = FooService.GetPagedFooBars(
new PagingSettings(pageNum, pageSize));

ListViewPagedDataSource ds = new ListViewPagedDataSource();
ds.AllowServerPaging = true;
ds.DataSource = FooBars;
ds.MaximumRows = pageSize;
ds.StartRowIndex = pageNum;
//TotalCount is the total number of records in the entire set, not just those loaded.
ds.TotalRowCount = FooBars.TotalCount;

lvFooBars.DataSource = ds;
lvFooBars.DataBind();

pgrFooBars.PageSize = pageSize;
pgrFooBars.SetPageProperties(pageNum, FooBars.TotalCount, true);
}

PagedList 来自 RobConery 的有用帖子 http://blog.wekeroad.com/2007/12/10/aspnet-mvc-pagedlistt/ .

问题在于 DataPager 似乎使用 ListView 的 Count 属性来确定记录总数,在本例中为 20 条。不知何故,它需要知道总共有 1,500 条记录,而不是 20 条记录。 DataPager 有一个属性 TotalRowCount,但它是只读的。

我从未见过使用服务器端分页的 DataPager 示例,但假设它可以进行服务器端分页,否则 QueryStringField 属性有什么用?

我知道您可以使用 4GuysFromRolla 在此 https://web.archive.org/web/20211020140032/https://www.4guysfromrolla.com/articles/031506-1.aspx 所做的方法来创建自定义分页解决方案。 ,但在创建自定义解决方案之前,我首先想知道是否可以使用 DataPager 提供解决方案。

更新我对此了解得越多,就越得出这样的结论:这是不可能的,不幸的是,数据页程序是仅适用于小型网站的控件。如果控件构建正确的话,我想做的事情应该非常简单。我希望能够说

dpFooBars.TotalRowCountComputed = false;
dpFooBars.TotalRowCount = AnyNumberThatISoChoose;

我一直在寻找一些技巧来完成同样的事情,但似乎数据分页器的 TotalRowCount 是根据它绑定(bind)到的数据源中的实际项目数计算的。对我来说,微软会同时创建一个 ListViewPagedDataSource() 类和一个 DataPager 类,并且不让它们一起正常工作,这似乎很奇怪,但这似乎已经发生了。

更新 2(啊哈时刻?)从 .Net 2.0 开始,似乎可以通过使用 ObjectDataSource 并自定义 SelectCountMethod() 来进行服务器端分页。我相信应该可以自定义 ObjectDataSource 来满足我的需求。嗯。我周末要出去,所以我需要几天时间看看这是否有效。请继续关注,真正的信徒。

最佳答案

正是需要您所做的 - SQL Server 分页利用 listview、datapager 和 linq 数据源。正如您所说,TotalRowCount 是只读的。还有 SetPageProperties 方法可用于设置总行数,但这对我来说也不起作用。

但是我设法用这种方法欺骗了它。我有一个带有空项目模板的虚拟隐藏 ListView 。寻呼机将指向这个虚拟 ListView 而不是原始 ListView 。然后我们需要将虚拟 ListView 绑定(bind)到一个虚拟集合,该集合的项目数与原始数据源中的项目数相同。这将确保正确呈现寻呼机。这是标记。

<asp:DataPager ID="pdPagerBottom" runat="server" PagedControlID="lvDummy" PageSize="5" QueryStringField="page">
<Fields>
<asp:NumericPagerField ButtonType="Link" RenderNonBreakingSpacesBetweenControls="true" NextPageText="Next" PreviousPageText="Previous" ButtonCount="40" />
</Fields>
</asp:DataPager>

<asp:ListView ID="lvDummy" runat="server" Visible="false">
<ItemTemplate></ItemTemplate>
</asp:ListView>

<asp:ListView ID="lvPropertyList" runat="server">...</asp:ListView>

以及背后的代码

        var datasourceQuery = context.Properties.OrderBy(x => x.PropertyID).Skip(pdPagerBottom.StartRowIndex).Take(pdPagerBottom.PageSize);

this.lvPropertyList.DataSource = datasourceQuery;
this.lvPropertyList.DataBind();

this.lvDummy.DataSource = new List<int>(Enumerable.Range(0, context.Properties.Count()));
this.lvDummy.DataBind();

用 100k 条记录对其进行了测试。很不错。

关于asp.net - 如何将 DataPager 与服务器端分页结合使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3204600/

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