DataGrid中嵌套使用Repeater

王朝c#·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

本文描述了如何把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>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航