三十四基于DataList和Repeater跨页面的主从报表.docxVIP

  • 1
  • 0
  • 约 10页
  • 2018-03-23 发布于重庆
  • 举报

三十四基于DataList和Repeater跨页面的主从报表.docx

三十四基于DataList和Repeater跨页面的主从报表

在ASP.NET 2.0中操作数据之三十四:基于DataList和Repeater跨页面的主/从报表 作者:heker2007 字体:[ HYPERLINK javascript:turnbig() 增加? HYPERLINK javascript:turnsmall() 减小] 类型:转载 时间:2016-05-09 HYPERLINK /article/83841.htm \l comments ?我要评论 前面介绍了使用GridView实现跨页面的主/从报表,同样DataList和Repeater也可以实现相同功能。 导言   在前面一章里我们学习了如何在一个页里显示主/从信息.另外一种经常使用的模式就是将主从信息用两个页分别显示.在前面的跨页面的主/从报表 我们通过GridView显示所有的supplier来使用这个模式.GridView里包含一个HyperLinkField,链接到另外一个页,并将SupplierID通过querystring传过去.第二个页使用GridView列出了选中的supplier提供的product.   这样的两页主/从表也可以用DataList和Repeater来实现.唯一的区别是DataList和Repeater都不提供HyperLinkField.所以我们需要添加一个HyperLink控件或者在ItemTemplate里使用HTML a.HyperLink的NavigateUrl属性和a的href属性可以通过声明或者编程来自定义. 本章我们将探讨使用Repeater列出categories.每个list item都包含了category的name和description.通过name可以直接链接到第二个页面.在第二页里用DataList显示选中的categroy提供的proudct. 第一步: 列出Categories   所有创建主从表的第一步都是显示主记录.因此,我们首先在主页里显示categories.打开DataListRepeaterFiltering文件夹里的CategoryListMaster.aspx页,添加一个Repeater,然后通过智能标签添加一个ObjectDataSource.使用CategriesBLL类的GetCategories方法配置它.见图1. 图 1:使用CategoriesBLL类的GetCategories方法配置ObjectDataSource 我们先不关心如何添加link.将Repeater的template配置成显示每个category的name和description.见下面的代码: HYPERLINK /article/83841.htm ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 asp:Repeater ID=Repeater1 runat=server DataSourceID=ObjectDataSource1 ?EnableViewState=False ?HeaderTemplate ?ul ?/HeaderTemplate ?? ?ItemTemplate ?li%# Eval(CategoryName) % - %# Eval(Description) %/li ?/ItemTemplate ?? ?FooterTemplate ?/ul ?/FooterTemplate /asp:Repeater ?? asp:ObjectDataSource ID=ObjectDataSource1 runat=server ?OldValuesParameterFormatString=original_{0} ?SelectMethod=GetCategories TypeName=CategoriesBLL /asp:ObjectDataSource 完成了上面的代码后,在浏览器里浏览页面.如图2所示. 图 2: 列出所有的 Category 第二步: 将Category Name 转换成链到Details Page 的Link   我们现在来添加一个link,当用户点击时,将会链到第二个页(ProductsForCategoryDetails.aspx),在这个页里显示从信息.这页里用DataList显示选中的category的product.为了判断是哪个category的链接被点了,我们需要将CategoryID传到第二页.最直接的方法是通过querystring.我们通过名为CategoryID的querystring字段将这个传给ProductsForCategoryDetails.aspx.例如,查看Beverages categroy下的produ

文档评论(0)

1亿VIP精品文档

相关文档