ASP.NET中GridView中嵌套GridView

//aspx页面
<asp:GridView ID="GridView2" runat="server" AutoGenerateColumns="False" GridLines="None"
                                    ShowHeader="False" OnRowDataBound="GridView2_RowDataBound">
               <Columns>
                     <asp:TemplateField>
                             <ItemTemplate>
                                 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="true">
                                 </asp:GridView>
                              </ItemTemplate>
                      </asp:TemplateField>
              </Columns>
  </asp:GridView>
//aspx.cs页面
protected void GridView2_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            GridView Grd = e.Row.Cells[0].FindControl("GridView1") as GridView;
            Grd.DataSource = 数据集;
            Grd.DataBind();
        }      
    }
*******************************************************************
gridview嵌套gridview
++++++++++.aspx代码++++++++++++++++
OnRowDataBound事件,与1.x中的ItemDataBound有一腿.
<!--第一层GridView开始-->
    <asp:GridView ID="GridView1"  OnRowDataBound="GridView1_RowDataBound"  AutoGenerateColumns=false runat="server">
      <Columns>
        <asp:TemplateField>
        <ItemTemplate>
           <%#Container.DataItem.ToString()%>
               <!--第二层GridView开始-->
               <asp:GridView ID="GridView2" OnRowDataBound="GridView2_RowDataBound"   AutoGenerateColumns=false runat="server">         
                 <Columns>
                  <asp:TemplateField>
                  <ItemTemplate>
                      <%#Container.DataItem.ToString()%>
                       <!--第三层GridView开始-->
                      <asp:GridView ID="GridView3"  AutoGenerateColumns=false runat=server>
                           <Columns>
                             <asp:TemplateField>
                             <ItemTemplate>
                              <%#Container.DataItem.ToString()%>
                             </ItemTemplate>
                             </asp:TemplateField>                   
                           </Columns>
                        </asp:GridView>
                       <!--第三层GridView 结束-->
                      
                   </ItemTemplate>
                  </asp:TemplateField>
                 </Columns>
                </asp:GridView>
              <!--第二层GridView结束-->
             
          </ItemTemplate>
          </asp:TemplateField>
         </Columns>
        </asp:GridView>
         <!--第一层GridView结束-->
++++++++++.cs代码++++++++++++++++
RowDataBound与1.x中的ItemDataBound也有一腿!
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Collections;
public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        this.GridView1.DataSource = Al("GridView1Item:");
        this.GridView1.DataBind();
    }
    //DataSource
    protected ArrayList Al(string GetStr)
    {
        ArrayList al = new ArrayList();
        for(int i=0;i<2;i++)
        {
            al.Add(GetStr+i.ToString());
        }
        return al;
    }
    //GridView1_RowDataBound
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            GridView gv = (GridView)e.Row.FindControl("GridView2");
            gv.DataSource = Al("GridView2Item:");
            gv.DataBind();
           
        }
    }
    //GridView2_RowDataBound
    protected void GridView2_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            GridView gv = (GridView)e.Row.FindControl("GridView3");
            gv.DataSource = Al("GridView3Item:");
            gv.DataBind();
        }
    }
}
发布了76 篇原创文章 · 获赞 11 · 访问量 25万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览