DataGrid中嵌套使用Repeater

本文介绍了将Repeater控件嵌套进DataGrid以显示分级数据的技术,该技术也可用于其他列表绑定控件组合。文中给出了完整代码,强调DataGrid的数据源绑定操作要在数据集关系添加之后进行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

本文描述了如何把Repeater 控件嵌套进DataGrid来显示分级的数据 。当然,你也可以将这一技术应用到其他的列表绑定控件上去,比如DataGrid包含DataGrid,DataList包含DataList等等的组合。

 

完整的代码 如下,要注意的是,

 

   DataGrid1.DataSource=dv;

    DataGrid1.DataBind();

 

一定要在ds.Relations.Add(..)之后..

 

<%@import namespace="System.Data" %>

<%@import namespace="System.Data.OleDb"%>

<script language="c#" runat="server">

string connstr=ConfigurationSettings.AppSettings["ConnectionString"];

 

//小区信息

string sql="select * from location where location_id in(select location from catalyst)";

//交换机信息

string sqltext="select * from catalyst order by location desc";

 

private void page_load(Object obj,EventArgs e)

{

  if(!Page.IsPostBack)

   {

     Dataload();

   }

}

 

private void Dataload()

{

     try

  { 

    OleDbConnection conn=new  OleDbConnection(connstr);

    DataSet ds=new DataSet();

    OleDbDataAdapter da=new OleDbDataAdapter(sql,conn);

    da.Fill(ds,"location");

    DataView dv=new DataView(ds.Tables["location"]);

 

    OleDbDataAdapter da2=new OleDbDataAdapter(sqltext,conn);

    da2.Fill(ds,"catalyst");

    ds.Relations.Add("myrelation",ds.Tables["location"].Columns["location_id"],ds.Tables["catalyst"].Columns["location"]);

 

    DataGrid1.DataSource=dv;

    DataGrid1.DataBind();

 

    conn.Close();

  }

  catch(OleDbException ex)

  {

    info.Text=ex.Message;

  }                

}

</script>

<html>

<body>

<form runat=server>

 

<asp:DataGrid id="DataGrid1" runat="server" AutoGenerateColumns="false">

  <Columns>

   <asp:TemplateColumn HeaderText="小区名">

   <ItemTemplate>

      <%# DataBinder.Eval(Container.DataItem,"location_name") %>

   </ItemTemplate>

   </asp:TemplateColumn>

   <asp:TemplateColumn HeaderText="交换机编号">

   <ItemTemplate>

     <asp:Repeater id="ChildRepeater" DataSource='<%# ((DataRowView)Container.DataItem).Row.GetChildRows("myrelation") %>' runat="server">

         <ItemTemplate>

            <%# Container.ItemIndex+1%>.<%# DataBinder.Eval(Container.DataItem, "[/"label/"]")%><br>

         </ItemTemplate>

      </asp:Repeater>

   </ItemTemplate>

   </asp:TemplateColumn>

  </Columns>

</asp:DataGrid>

 

 

</form>

<asp:label id="info" forecolor="blue" runat="server"/>

</body>

</html>

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值