ListView(3)

7.4.6  ListView(3)

3. ListView分页和Pager控件

ASP.NET 3.5引入了另一个新控件DataPager,ListView使用它为自己提供分页功能。DataPager控件用于给终端用户显示分页的导航,并与实 现了IPagableItemContainer接口的数据绑定控件(在ASP.NET 3.5中就是ListView控件)一起完成数据分页任务。事实上,如果在ListView配置对话框中选择Paging复选框,激活ListView控 件上的分页功能,该控件就会在其LayoutTemplate中插入一个新的DataPager控件。ListView为Grid布局生成的默认分页标记 如下:


<asp:datapager ID="DataPager1" runat="server">
<Fields>
<asp:nextpreviouspagerfield ButtonType="Button" FirstPageText="First"
LastPageText="Last" NextPageText="Next" PreviousPageText="Previous"
ShowFirstPageButton="True" ShowLastPageButton="True" />
</Fields>
</asp:datapager>

该控件的标记显示,在DataPager中创建了一个Fields集合,它包含一个NextPreviousPagerField对象。顾名思义, 使用NextPreviousPager对象会使DataPager显示Next和Previous按钮,作为其用户界面。DataPager控件包含3 类Field对象:NextPreviousPagerField、NumericPagerField和TemplatePagerField对象。 NumericPagerField对象会生成一个简单的编号页面列表,而TemplatePagerField可以指定定制的分页用户界面。这些不同的 Field类型都包含许多属性,可用于控制DataPager显示用户界面的方式。另外,DataPager包含一个Fields集合,而不是一个简单的 Field属性,所以可以在一个DataPager控件中显示几种不同的Field对象。

TemplatePagerField是一种独特的Field对象,它不包含用户界面本身,而只包含一个模板,用于完全定制分页的用户界面。程序清单7-56演示了TemplatePagerField的使用。

程序清单7-56  创建定制的DataPager用户界面

<asp:DataPager ID="DataPager1" runat="server">
<Fields>
<asp:TemplatePagerField>
<PagerTemplate>
Page
<asp:Label runat="server"
Text="<%# (Container.StartRowIndex/Container.PageSize)+1%>" />
of
<asp:Label runat="server"
Text="<%# Container.TotalRowCount/Container.PageSize%>" />
</PagerTemplate>
</asp:TemplatePagerField>
</Fields>
</asp:DataPager>

注意这个例子使用ASP.NET数据绑定提供总页数、页面尺寸和页面开始的行,这些都是通过DataPager控件显示的。

如果要在PagerTemplate中使用定制的导航控件,例如用按钮控件改变当前显示的页面,就应为按钮创建标准的Click事件处理程序。在这 个事件处理程序中,可以访问DataPager的StartRowIndex、TotalRowCount和PageSize属性,计算ListView 在显示时应使用的新StartRowIndex。

与GridView提供的分页功能不同,DataPager是一个独立的控件,可以把它自由地放在Web页面上。前面的所有例子都是把DataPager控件直接放在ListView上,但这个控件可以放在Web窗体的任何地方。

程序清单7-57  把DataPager控件放在ListView的外部


<asp:DataPager ID="DataPager1" runat="server" PagedControlID="ListView1">
<Fields>
<asp:NumericPagerField />
</Fields>
</asp:DataPager>

在程序清单7-57中,一个重要的变化是使用了PagedControlID属性,它可以指定这个分页器应使用哪个控件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值