数据控件嵌套的几种方法
俺的方法:
 <asp:Repeater ID="myrpList" runat="server">
<asp:Repeater ID="myrpList" runat="server">
 <HeaderTemplate>
          <HeaderTemplate>
 <table width="100%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF">
          <table width="100%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF">
 </HeaderTemplate>
          </HeaderTemplate>
 <ItemTemplate>
          <ItemTemplate>
 <tr>
            <tr>
 <td width="4%" height="25" valign="top"> </td>
              <td width="4%" height="25" valign="top"> </td>
 <td width="96%" valign="top"><strong><%# Eval("classname")%></strong></td>
              <td width="96%" valign="top"><strong><%# Eval("classname")%></strong></td>
 </tr>
            </tr>
 <tr>
            <tr>
 <td height="25" valign="top"> </td>
              <td height="25" valign="top"> </td>
 <td valign="top">
              <td valign="top">
 <asp:DataList ID="mydList" runat="server"><HeaderTemplate>
               <asp:DataList ID="mydList" runat="server"><HeaderTemplate>
 <table width="100%" border="0" cellspacing="0" cellpadding="0">
                <table width="100%" border="0" cellspacing="0" cellpadding="0">
 </HeaderTemplate>
                  </HeaderTemplate>         
 <ItemTemplate>
                    <ItemTemplate>
 <tr>
                  <tr>
 <td> <%# Eval("title")%></td>
                    <td> <%# Eval("title")%></td>
 </tr>
                  </tr>
 </ItemTemplate>
                    </ItemTemplate>
 <FooterTemplate>
                    <FooterTemplate>
 </table></FooterTemplate></asp:DataList></td>
                </table></FooterTemplate></asp:DataList></td>
 </tr>
            </tr> 
 </ItemTemplate>
            </ItemTemplate>
 <FooterTemplate>
            <FooterTemplate>
 </table>
          </table> 
 </FooterTemplate>
          </FooterTemplate>             
 </asp:Repeater>
          </asp:Repeater>
CS:
 void BinData()
    void BinData()
 {
    {
 WebClass.ArticleList tmp = new WebClass.ArticleList();
        WebClass.ArticleList tmp = new WebClass.ArticleList();
 DataTable dt = tmp.ListClass();
        DataTable dt = tmp.ListClass();
 this.myrpList.DataSource = dt;
        this.myrpList.DataSource = dt;
 this.myrpList.DataBind();
        this.myrpList.DataBind();

 int strID;
        int strID;
 foreach (RepeaterItem it in this.myrpList.Items)
        foreach (RepeaterItem it in this.myrpList.Items)
 {
        {
 int i = int.Parse(it.ItemIndex.ToString());
            int i = int.Parse(it.ItemIndex.ToString());
 strID = int.Parse(dt.Rows[i]["id"].ToString());
            strID = int.Parse(dt.Rows[i]["id"].ToString());
 DataList dlist = (DataList)it.FindControl("mydList");
            DataList dlist = (DataList)it.FindControl("mydList");

 dlist.DataSource = tmp.ShowClassAricle(strID);
            dlist.DataSource = tmp.ShowClassAricle(strID);
 dlist.DataBind();
            dlist.DataBind();
 }
        }
 }
    }
网上看到的:
 //在绑定分类品名时,绑定分类下的产品
//在绑定分类品名时,绑定分类下的产品 
 private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e) 
 {
{ 
 BLL.Products products =new BLL.Products();
    BLL.Products products =new BLL.Products(); 
 if (e.Item.ItemType == ListItemType.Item ||    e.Item.ItemType == ListItemType.AlternatingItem)
    if (e.Item.ItemType == ListItemType.Item ||    e.Item.ItemType == ListItemType.AlternatingItem)  
 {
    { 
 Repeater rptProduct = (Repeater) e.Item.FindControl("rptProduct");
        Repeater rptProduct = (Repeater) e.Item.FindControl("rptProduct"); 
 //找到分类Repeater关联的数据项
        //找到分类Repeater关联的数据项 
 DataRowView rowv = (DataRowView)e.Item.DataItem;
        DataRowView rowv = (DataRowView)e.Item.DataItem; 
 //提取分类ID
        //提取分类ID 
 int CategorieId = Convert.ToInt32(rowv["ID"]);
        int CategorieId = Convert.ToInt32(rowv["ID"]); 
 //根据分类ID查询该分类下的产品,并绑定产品Repeater
        //根据分类ID查询该分类下的产品,并绑定产品Repeater 
 rptProduct.DataSource = products.GetProductsByCategorieId(CategorieId);
        rptProduct.DataSource = products.GetProductsByCategorieId(CategorieId); 
 rptProduct.DataBind();
        rptProduct.DataBind(); 
 }
    } 
 }
} 
还有一种方法:
 <!-- start parent repeater -->
<!-- start parent repeater -->
 <asp:repeater id="parentRepeater" runat="server">
<asp:repeater id="parentRepeater" runat="server">
 <itemtemplate>
   <itemtemplate>
 <b><%# DataBinder.Eval(Container.DataItem,"au_id") %></b><br>
      <b><%# DataBinder.Eval(Container.DataItem,"au_id") %></b><br>

 <!-- start child repeater -->
      <!-- start child repeater -->
 <asp:repeater id="childRepeater" datasource='<%# ((DataRowView)Container.DataItem)
      <asp:repeater id="childRepeater" datasource='<%# ((DataRowView)Container.DataItem)
 .Row.GetChildRows("myrelation") %>' runat="server">
      .Row.GetChildRows("myrelation") %>' runat="server">

 <itemtemplate>
         <itemtemplate>
 <%# DataBinder.Eval(Container.DataItem, "[\"title_id\"]")%><br>
            <%# DataBinder.Eval(Container.DataItem, "[\"title_id\"]")%><br>
 </itemtemplate>
         </itemtemplate>
 </asp:repeater>
      </asp:repeater>
 <!-- end child repeater -->
      <!-- end child repeater -->

 </itemtemplate>
   </itemtemplate>
 </asp:repeater>
</asp:repeater>
 <!-- end parent repeater -->
<!-- end parent repeater -->
 
cs:
 public void Page_Load(object sender, EventArgs e)
   public void Page_Load(object sender, EventArgs e)
 {
    {
 //Create the connection and DataAdapter for the Authors table.
        //Create the connection and DataAdapter for the Authors table.
 SqlConnection cnn = new SqlConnection("server=.;database=pubs; user id=sa;pwd=;");
        SqlConnection cnn = new SqlConnection("server=.;database=pubs; user id=sa;pwd=;");
 SqlDataAdapter cmd1 = new SqlDataAdapter("select * from authors", cnn);
        SqlDataAdapter cmd1 = new SqlDataAdapter("select * from authors", cnn);

 //Create and fill the DataSet.
        //Create and fill the DataSet.
 DataSet ds = new DataSet();
        DataSet ds = new DataSet();
 cmd1.Fill(ds, "authors");
        cmd1.Fill(ds, "authors");

 //Create a second DataAdapter for the Titles table.
        //Create a second DataAdapter for the Titles table.
 SqlDataAdapter cmd2 = new SqlDataAdapter("select * from titleauthor", cnn);
        SqlDataAdapter cmd2 = new SqlDataAdapter("select * from titleauthor", cnn);
 cmd2.Fill(ds, "titles");
        cmd2.Fill(ds, "titles");

 //Create the relation bewtween the Authors and Titles tables.
        //Create the relation bewtween the Authors and Titles tables.
 ds.Relations.Add("myrelation",
        ds.Relations.Add("myrelation",
 ds.Tables["authors"].Columns["au_id"],
        ds.Tables["authors"].Columns["au_id"],
 ds.Tables["titles"].Columns["au_id"]);
        ds.Tables["titles"].Columns["au_id"]);

 //Bind the Authors table to the parent Repeater control, and call DataBind.
        //Bind the Authors table to the parent Repeater control, and call DataBind.
 parentRepeater.DataSource = ds.Tables["authors"];
        parentRepeater.DataSource = ds.Tables["authors"];
 Page.DataBind();
        Page.DataBind();

 //Close the connection.
        //Close the connection.
 cnn.Close();
        cnn.Close();
 }
    }
 
 <asp:Repeater ID="myrpList" runat="server">
<asp:Repeater ID="myrpList" runat="server"> <HeaderTemplate>
          <HeaderTemplate> <table width="100%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF">
          <table width="100%" border="0" align="center" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF"> </HeaderTemplate>
          </HeaderTemplate> <ItemTemplate>
          <ItemTemplate> <tr>
            <tr> <td width="4%" height="25" valign="top"> </td>
              <td width="4%" height="25" valign="top"> </td> <td width="96%" valign="top"><strong><%# Eval("classname")%></strong></td>
              <td width="96%" valign="top"><strong><%# Eval("classname")%></strong></td> </tr>
            </tr> <tr>
            <tr> <td height="25" valign="top"> </td>
              <td height="25" valign="top"> </td> <td valign="top">
              <td valign="top"> <asp:DataList ID="mydList" runat="server"><HeaderTemplate>
               <asp:DataList ID="mydList" runat="server"><HeaderTemplate> <table width="100%" border="0" cellspacing="0" cellpadding="0">
                <table width="100%" border="0" cellspacing="0" cellpadding="0"> </HeaderTemplate>
                  </HeaderTemplate>          <ItemTemplate>
                    <ItemTemplate> <tr>
                  <tr> <td> <%# Eval("title")%></td>
                    <td> <%# Eval("title")%></td> </tr>
                  </tr> </ItemTemplate>
                    </ItemTemplate> <FooterTemplate>
                    <FooterTemplate> </table></FooterTemplate></asp:DataList></td>
                </table></FooterTemplate></asp:DataList></td> </tr>
            </tr>  </ItemTemplate>
            </ItemTemplate> <FooterTemplate>
            <FooterTemplate> </table>
          </table>  </FooterTemplate>
          </FooterTemplate>              </asp:Repeater>
          </asp:Repeater>CS:
 void BinData()
    void BinData() {
    { WebClass.ArticleList tmp = new WebClass.ArticleList();
        WebClass.ArticleList tmp = new WebClass.ArticleList(); DataTable dt = tmp.ListClass();
        DataTable dt = tmp.ListClass(); this.myrpList.DataSource = dt;
        this.myrpList.DataSource = dt; this.myrpList.DataBind();
        this.myrpList.DataBind();
 int strID;
        int strID; foreach (RepeaterItem it in this.myrpList.Items)
        foreach (RepeaterItem it in this.myrpList.Items) {
        { int i = int.Parse(it.ItemIndex.ToString());
            int i = int.Parse(it.ItemIndex.ToString()); strID = int.Parse(dt.Rows[i]["id"].ToString());
            strID = int.Parse(dt.Rows[i]["id"].ToString()); DataList dlist = (DataList)it.FindControl("mydList");
            DataList dlist = (DataList)it.FindControl("mydList");
 dlist.DataSource = tmp.ShowClassAricle(strID);
            dlist.DataSource = tmp.ShowClassAricle(strID); dlist.DataBind();
            dlist.DataBind(); }
        } }
    }网上看到的:
 //在绑定分类品名时,绑定分类下的产品
//在绑定分类品名时,绑定分类下的产品  private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
private void rptCategories_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)  {
{  BLL.Products products =new BLL.Products();
    BLL.Products products =new BLL.Products();  if (e.Item.ItemType == ListItemType.Item ||    e.Item.ItemType == ListItemType.AlternatingItem)
    if (e.Item.ItemType == ListItemType.Item ||    e.Item.ItemType == ListItemType.AlternatingItem)   {
    {  Repeater rptProduct = (Repeater) e.Item.FindControl("rptProduct");
        Repeater rptProduct = (Repeater) e.Item.FindControl("rptProduct");  //找到分类Repeater关联的数据项
        //找到分类Repeater关联的数据项  DataRowView rowv = (DataRowView)e.Item.DataItem;
        DataRowView rowv = (DataRowView)e.Item.DataItem;  //提取分类ID
        //提取分类ID  int CategorieId = Convert.ToInt32(rowv["ID"]);
        int CategorieId = Convert.ToInt32(rowv["ID"]);  //根据分类ID查询该分类下的产品,并绑定产品Repeater
        //根据分类ID查询该分类下的产品,并绑定产品Repeater  rptProduct.DataSource = products.GetProductsByCategorieId(CategorieId);
        rptProduct.DataSource = products.GetProductsByCategorieId(CategorieId);  rptProduct.DataBind();
        rptProduct.DataBind();  }
    }  }
} 还有一种方法:
 <!-- start parent repeater -->
<!-- start parent repeater --> <asp:repeater id="parentRepeater" runat="server">
<asp:repeater id="parentRepeater" runat="server"> <itemtemplate>
   <itemtemplate> <b><%# DataBinder.Eval(Container.DataItem,"au_id") %></b><br>
      <b><%# DataBinder.Eval(Container.DataItem,"au_id") %></b><br>
 <!-- start child repeater -->
      <!-- start child repeater --> <asp:repeater id="childRepeater" datasource='<%# ((DataRowView)Container.DataItem)
      <asp:repeater id="childRepeater" datasource='<%# ((DataRowView)Container.DataItem) .Row.GetChildRows("myrelation") %>' runat="server">
      .Row.GetChildRows("myrelation") %>' runat="server">
 <itemtemplate>
         <itemtemplate> <%# DataBinder.Eval(Container.DataItem, "[\"title_id\"]")%><br>
            <%# DataBinder.Eval(Container.DataItem, "[\"title_id\"]")%><br> </itemtemplate>
         </itemtemplate> </asp:repeater>
      </asp:repeater> <!-- end child repeater -->
      <!-- end child repeater -->
 </itemtemplate>
   </itemtemplate> </asp:repeater>
</asp:repeater> <!-- end parent repeater -->
<!-- end parent repeater -->
cs:
 public void Page_Load(object sender, EventArgs e)
   public void Page_Load(object sender, EventArgs e) {
    { //Create the connection and DataAdapter for the Authors table.
        //Create the connection and DataAdapter for the Authors table. SqlConnection cnn = new SqlConnection("server=.;database=pubs; user id=sa;pwd=;");
        SqlConnection cnn = new SqlConnection("server=.;database=pubs; user id=sa;pwd=;"); SqlDataAdapter cmd1 = new SqlDataAdapter("select * from authors", cnn);
        SqlDataAdapter cmd1 = new SqlDataAdapter("select * from authors", cnn);
 //Create and fill the DataSet.
        //Create and fill the DataSet. DataSet ds = new DataSet();
        DataSet ds = new DataSet(); cmd1.Fill(ds, "authors");
        cmd1.Fill(ds, "authors");
 //Create a second DataAdapter for the Titles table.
        //Create a second DataAdapter for the Titles table. SqlDataAdapter cmd2 = new SqlDataAdapter("select * from titleauthor", cnn);
        SqlDataAdapter cmd2 = new SqlDataAdapter("select * from titleauthor", cnn); cmd2.Fill(ds, "titles");
        cmd2.Fill(ds, "titles");
 //Create the relation bewtween the Authors and Titles tables.
        //Create the relation bewtween the Authors and Titles tables. ds.Relations.Add("myrelation",
        ds.Relations.Add("myrelation", ds.Tables["authors"].Columns["au_id"],
        ds.Tables["authors"].Columns["au_id"], ds.Tables["titles"].Columns["au_id"]);
        ds.Tables["titles"].Columns["au_id"]);
 //Bind the Authors table to the parent Repeater control, and call DataBind.
        //Bind the Authors table to the parent Repeater control, and call DataBind. parentRepeater.DataSource = ds.Tables["authors"];
        parentRepeater.DataSource = ds.Tables["authors"]; Page.DataBind();
        Page.DataBind();
 //Close the connection.
        //Close the connection. cnn.Close();
        cnn.Close(); }
    }
 
                     
                    
                 
                    
                 
              
 
         
                
            
         
 
         浙公网安备 33010602011771号
浙公网安备 33010602011771号