asp.net中Repeater嵌套绑定的方法(使用两个Repeater做子类别绑定)
2010-06-30 18:41
483 查看
这篇文章主要讲解了在asp.net中Repeater控件嵌套绑定的问题,一般我们用两个Repeater控件嵌套绑定来实现类别和类别下信息的绑定。
在一般的网站中浏览类别的用户控件通常都位于大多数 ASP.NET 页的左边,它使用户能够按类别快速的查找产品。最近遇到一个客户,因为在他网站上展示的产品并不多,所以要求在原有类别浏览的基础上将产品也加进去。一来更方便,二来加长了左部导航栏的长度使页面更协调。原有的分类导航栏是由Repeater实现的,现在需要在每一个分类下加入该类的商品信息,于是我想到了在原有Repeater中嵌套Repeater。实现界面如下:
前台页面部分:
<asp:Repeater id="rptCategories" runat="server">
<HeaderTemplate>
<table width="100%" border="0" cellspacing="0" cellpadding="0">
</HeaderTemplate>
<ItemTemplate>
<!--分类名称-->
<tr><th><%# DataBinder.Eval(Container.DataItem, "TypeName") %></th></tr>
<!--分类下的产品-->
<asp:Repeater id="rptProduct" runat="server">
<ItemTemplate>
<tr><td><a href='ProductInfo.aspx?Id=<%# DataBinder.Eval(Container.DataItem, "ID") %>'><%# DataBinder.Eval(Container.DataItem, "ProductName") %></a></td></tr>
</ItemTemplate>
</asp:Repeater>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>
后台代码部分(部分代码):
//在绑定分类品名时,绑定分类下的产品
//商品分类名称rptCategories绑定省略,正常绑定即可,下面代码为商品分类名称rptCategories的ItemDataBound事件
private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
{
Repeater rptProduct = (Repeater)e.Item.FindControl("rptProduct");
//找到商品分类编号
object CategorieId = DataBinder.Eval(e.Item.DataItem, "ID");
//根据分类ID查询该分类下的产品,并绑定产品Repeater
rptProduct.DataSource = 获取产品列表的方法(参数:Convert.ToString(CategorieId));
rptProduct.DataBind();
}
在一般的网站中浏览类别的用户控件通常都位于大多数 ASP.NET 页的左边,它使用户能够按类别快速的查找产品。最近遇到一个客户,因为在他网站上展示的产品并不多,所以要求在原有类别浏览的基础上将产品也加进去。一来更方便,二来加长了左部导航栏的长度使页面更协调。原有的分类导航栏是由Repeater实现的,现在需要在每一个分类下加入该类的商品信息,于是我想到了在原有Repeater中嵌套Repeater。实现界面如下:
前台页面部分:
<asp:Repeater id="rptCategories" runat="server">
<HeaderTemplate>
<table width="100%" border="0" cellspacing="0" cellpadding="0">
</HeaderTemplate>
<ItemTemplate>
<!--分类名称-->
<tr><th><%# DataBinder.Eval(Container.DataItem, "TypeName") %></th></tr>
<!--分类下的产品-->
<asp:Repeater id="rptProduct" runat="server">
<ItemTemplate>
<tr><td><a href='ProductInfo.aspx?Id=<%# DataBinder.Eval(Container.DataItem, "ID") %>'><%# DataBinder.Eval(Container.DataItem, "ProductName") %></a></td></tr>
</ItemTemplate>
</asp:Repeater>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:Repeater>
后台代码部分(部分代码):
//在绑定分类品名时,绑定分类下的产品
//商品分类名称rptCategories绑定省略,正常绑定即可,下面代码为商品分类名称rptCategories的ItemDataBound事件
private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
{
Repeater rptProduct = (Repeater)e.Item.FindControl("rptProduct");
//找到商品分类编号
object CategorieId = DataBinder.Eval(e.Item.DataItem, "ID");
//根据分类ID查询该分类下的产品,并绑定产品Repeater
rptProduct.DataSource = 获取产品列表的方法(参数:Convert.ToString(CategorieId));
rptProduct.DataBind();
}
相关文章推荐
- asp.net中Repeater嵌套绑定的方法(使用两个Repeater做子类别绑定)
- asp.net中Repeater嵌套绑定的方法(查询新闻类别和新闻类别下的新闻) .
- asp.net asp:Repeater嵌套绑定方法(2)
- asp.net asp:Repeater嵌套绑定方法(1)
- asp.net实现DataList与Repeater嵌套绑定的方法
- asp.net实现DataList与Repeater嵌套绑定的方法
- asp.net 在使用repeater控件时截取绑定字符方法
- asp.net控件用法--在Repeater中嵌套使用Repeater
- ASP.NET Repeater控件的嵌套使用
- asp.net 数据绑定 使用eval 时候报 字符文本中的字符太多 问题的解决方法
- asp.net数据绑定DataBind使用方法
- 关于使用asp.net 的分页显示数据。Repeater绑定数据后的分页显示。
- asp.net 中 Repeater嵌套使用的方法
- ASP.NET中 Repeater 的使用前台绑定
- asp.net Repeater绑定时使用函数
- asp.net数据绑定DataBind使用方法
- 在ASP.NET MVC中使用Knockout实践02,组合View Model成员、Select绑定、通过构造器创建View Model,扩展View Model方法
- Asp.Net Repeater中使用Button控件并响应单击操作的方法
- asp.net(C#)中Repeater嵌套绑定Repeater
- asp.net(C#)中Repeater嵌套绑定Repeater