在ASP.NET2.0中操作数据之三十四:基于DataList和Repeater跨页面的主/从报表作者:heker2007字体:[增加减小]类型:转载时间:2016-05-09我要评论前面介绍了使用GridView实现跨页面的主/从报表,同样DataList和Repeater也可以实现相同功能。导言在前面一章里我们学习了如何在一个页里显示主/从信息.另外一种经常使用的模式就是将主从信息用两个页分别显示.在前面的跨页面的主/从报表我们通过GridView显示所有的supplier来使用这个模式.GridView里包含一个HyperLinkField,链接到另外一个页,并将SupplierID通过querystring传过去.第二个页使用GridView列出了选中的supplier提供的product.这样的两页主/从表也可以用DataList和Repeater来实现.唯一的区别是DataList和Repeater都不提供HyperLinkField.所以我们需要添加一个HyperLink控件或者在ItemTemplate里使用HTMLa.HyperLink的NavigateUrl属性和a的href属性可以通过声明或者编程来自定义.本章我们将探讨使用Repeater列出categories.每个listitem都包含了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.见下面的代码:?12345678910111213asp:RepeaterID=Repeater1runat=serverDataSourceID=ObjectDataSource1EnableViewState=FalseHeaderTemplateul/HeaderTemplateItemTemplateli%#Eval(CategoryName)%-%#Eval(Description)%/li/ItemTemplateFooterTemplate/ul/FooterTemplate/asp:Repeaterasp:ObjectDataSourceID=ObjectDataSource1runat=serverOldValuesParameterFormatString=original_{0}SelectMethod=GetCategoriesTypeName=CategoriesBLL141516171819/asp:ObjectDataSource完成了上面的代码后,在浏览器里浏览页面.如图2所示.图2:列出所有的Category第二步:将CategoryName转换成链到DetailsPage的Link我们现在来添加一个link,当用户点击时,将会链到第二个页(ProductsForCategoryDetails.aspx),在这个页里显示从信息.这页里用DataList显示选中的category的product.为了判断是哪个category的链接被点了,我们需要将CategoryID传到第二页.最直接的方法是通过querystring.我们通过名为CategoryID的querystring字段将这个传给ProductsForCategoryDetails.aspx.例如,查看Beveragescategroy下的product,CategoryID为1.用户将访问ProductsForCategoryDetails.aspx?CategoryID=1页.为了创建hyperlink我们需要添加HyperLink控件或者在ItemTemplate里添加HTMLa.在每行的hyperlink都相同的情况下,两种方法都足够了.对Repeater来说我更愿意使用a.见下面的代码:?12345liahref='ProductsForCategoryDetails.aspx?CategoryID=%#Eval(CategoryID)%'%#Eval(CategoryName)%/a-%#Eval(Description)%/li注意CategoryID可以直接通过href属性写入.注意引号和省略号.?1234567liasp:HyperLinkrunat=serverText='%#Eval(CategoryName)%'NavigateUrl='%#ProductsForCategoryDetails.aspx?CategoryID=&Eval(CategoryID)%'/asp:HyperLink-%#Eval(Description)%/li注意在绑定语法里静态URL—ProductsForCategoryDetails.aspx?CategoryID—是如何直接和Eval(CategoryID)的结果串联.使用HyperLink控件的一个好处是如果需要的话可以编程访问Repeater的ItemDataBoundeventhandler.例如你可以将没有关联product的categories显示为文本,而不是link.将那些没有关联product的categories的HyperLink的NavigateUrl属性设为一个空的字符串,这样categoryname就显示为一个text(而不是link).更多的通过ItemDataBoundeventhandler的编程来格式化DataList和Repeater内容的信息请看格式化DataList和Repeater的数据.如果你在跟着教程做的话,使用上面两种方法都可以.当浏览这页时,每个categoryname都以link的形式呈现,可以链接到ProductsForCategoryDetails.aspx页,并将CategoryID的值传过去.见图3.图3:CategoryNames现在链接到ProductsForCategoryDetails.aspx页第三步:列出选中的Category下的Products完成CategoryListMaster.aspx页后,我们现在来完成从页,ProductsForCategoryDetails.aspx.打开这个页,拖一个DataList控件进来,并将ID设置为ProductsInCategory.然后在智能标签里选择添加一个名为ProductsInCategoryDataSource的ObjectDataSource.并用ProductsBLL类的GetProductsByCategoryID(categoryID)方法配置它.在INSERT,UPDATE,DELETE标签里选择None.图4:使用ProductsBLL类的GetProductsByCategoryID(categoryID)方法配置ObjectDataSource由于GetProductsByCategoryID(categoryID)方法接收一个参数,所以向导会提示我们指定参数来源.设置parametersource为QueryString,QueryStringField为CategoryID.图5:使用QuerystringField作为ParameterSource象前面教程里看到的那样,完成数据源配置后,VisualStudio会自动创建一个ItemTemplate列出每个字段的name和value.我们只显示name,supplier和price.将DataList的RepeatColumns属性设为2.完成这些后你的声明标记看起来应该和下面差不多:?123456789101112asp:DataListID=ProductsInCategoryrunat=serverDataKeyField=ProductIDRepeatColumns=2DataSourceID=ProductsInCategoryDataSourceEnableViewState=FalseItemTemplateh5%#Eval(ProductName)%/h5pSuppliedby%#Eval(SupplierName)%br/%#Eval(UnitPrice,{0:C})%/p/ItemTemplate/asp:DataListasp:ObjectDataSourceID=ProductsInCategoryDataSourceOldValuesParameterFormatString=original_{0}runat=serverSelectMethod=GetProductsByCategoryIDTypeName=ProductsBLLSelectParametersasp:QueryStringParameterName=categoryIDQueryStringField=CategoryID1314151617181920Type=Int32//SelectParameters/asp:ObjectDataSource现在我们来看看效果,先浏览CategoryListMater.aspx页.然后在列出的category上点一个link.这样就会跳到ProductsForCategoryDetails.aspx页,并将CategoryID通过querystring传过去.ProductsInCategoryDataSourceObjectDataSource会返回指定category的product并将它们显示在DataList中,每行两个.图6是点击Beverages的截图.图6:每行两个的显示Beverages第四步:在ProductsForCategoryDetails.aspx里显示Category信息当用户在CategoryListMaster.aspx页点击一个category时,会跳到ProductsForCategoryDetails.aspx页并显示选中的categry下的product.然而在这个页里并没有包含哪个category被选中了的信息.用户可能想点Beverages,但是结果点了Condiments,这时他没办法知道自己是否点错了.为了剞劂这个问题,我们可以将选中的category信息显示在ProductsForCategoryDetails.aspx页的顶部(name和description).在ProductsForCategoryDetails.aspx的Repeater上添加一个FormView.然后通过智能标签添加一个名为CategoryDataSource的ObjectDataSource,并用CategoriesBLL类的GetCategoryByCategoryID(categoryID)方法配置它.图7:配置CategoryDataSource在第三步增加ProductsInCategoryDataSourceObjectDataSource时,向导提示我们为GetCategoryByCateg