在一般的网站中浏览类别的用户控件通常都位于大多数 ASP.NET 页的左边,它使用户能够按类别快速的查找产品。最近遇到一个客户,因为在他网站上展示的产品并不多,所以要求在原有类别浏览的基础上将产品也加进去。一来更方便,二来加长了左部导航栏的长度使页面更协调。原有的分类导航栏是由Repeater实现的,现在需要在每一个分类下加入该类的商品信息,于是我想到了在原有Repeater中嵌套Repeater。实现界面如下:
data:image/s3,"s3://crabby-images/e089b/e089b7498a7cc92ca3b3d6164a64588ab0b1ad47" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
前台页面部分:
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<asp:Repeater id="rptCategories" runat="server">
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<HeaderTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<table width="100%" border="0" cellspacing="0" cellpadding="0">
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</HeaderTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<ItemTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<!--分类名称-->
data:image/s3,"s3://crabby-images/14e11/14e118dea174587686bf738ba7dc2a1c900873db" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<tr><th><%# DataBinder.Eval(Container.DataItem, "TypeName") %></th></tr>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<!--分类下的产品-->
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<asp:Repeater id="rptProduct" runat="server">
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<ItemTemplate>
data:image/s3,"s3://crabby-images/14e11/14e118dea174587686bf738ba7dc2a1c900873db" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<tr><td><a href='ProductInfo.aspx?Id=<%# DataBinder.Eval(Container.DataItem, "ID") %>'><%# DataBinder.Eval(Container.DataItem, "ProductName") %></a></td></tr>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</ItemTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</asp:Repeater>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</ItemTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
<FooterTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</table>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</FooterTemplate>
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
</asp:Repeater>
后台代码部分(部分代码):
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
//在绑定分类品名时,绑定分类下的产品
data:image/s3,"s3://crabby-images/f122e/f122ec0cb39d1ab69fa6e538ae7cd1206b26676b" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
data:image/s3,"s3://crabby-images/14e11/14e118dea174587686bf738ba7dc2a1c900873db" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
{
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
BLL.Products products =new BLL.Products();
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
data:image/s3,"s3://crabby-images/e1adb/e1adbf41251cc1469c8996fce2ce30812e4b7ff9" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
{
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
Repeater rptProduct = (Repeater) e.Item.FindControl("rptProduct");
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
//找到分类Repeater关联的数据项
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
DataRowView rowv = (DataRowView)e.Item.DataItem;
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
//提取分类ID
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
int CategorieId = Convert.ToInt32(rowv["ID"]);
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
//根据分类ID查询该分类下的产品,并绑定产品Repeater
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
rptProduct.DataSource = products.GetProductsByCategorieId(CategorieId);
data:image/s3,"s3://crabby-images/d7731/d7731f52954d8a083cc86a8600968d24308f6e8a" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
rptProduct.DataBind();
data:image/s3,"s3://crabby-images/588f0/588f0f047f7a6ea7db7046b23b728cfe4c7f6184" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
}
data:image/s3,"s3://crabby-images/02320/023200d8b54eb77c7e96f7c1ceb527c4d1aa6400" alt="(转)在Repeater中嵌套使用Repeater (转)在Repeater中嵌套使用Repeater"
}