asp.net中Repeater嵌套绑定的方法(使用两个Repeater做子类别绑定)

方法一:

这篇文章主要讲解了在asp.net中Repeater控件嵌套绑定的问题,一般我们用两个Repeater控件嵌套绑定来实现类别和类别下信息的绑定。 在一般的网站中浏览类别的用户控件通常都位于大多数 ASP.NET 页的左边,它使用户能够按类别快速的查找产品。最近遇到一个客户,因为在他网站上展示的产品并不多,所以要求在原有类别浏览的基础上将产品也加进去。一来更方便,二来加长了左部导航栏的长度使页面更协调。原有的分类导航栏是由Repeater实现的,现在需要在每一个分类下加入该类的商品信息,于是我想到了在原有Repeater中嵌套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:repeater ID="Repeater1" runat="server">
        <ItemTemplate >
            <span style ="font-weight :bold "><%#Eval ("pname") %></span>
            <ul>
                <asp:Repeater ID="detal" runat ="server" DataSource ='<%#GetCity(Eval("pid").ToString()) %>'>
                    <ItemTemplate >
                        <li><%#Eval("city_name") %></li>
                    </ItemTemplate>
                </asp:Repeater>
            </ul>
        </ItemTemplate>
    </asp:repeater>

 

重点:DataSource ='<%#Getawd(Eval("pid").ToString()) %>'   调用GetCity方法获取子类

protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
             BindGrid();
     }
    //获取大类的类别
    protected void BindGrid()
    {
        string cmdText = "select pid, pname from pro";
         DataTable dt = vc.GetDataTable(cmdText );
         Repeater1.DataSource = dt;
         Repeater1.DataBind();
     }
    //获取小类内容
    protected DataTable GetCity(string   id)
    {
        string cmdText = "select city_name from city where promo_id = " + id + "";
         DataTable dt = vc.GetDataTable(cmdText);
        return dt;
     }

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值