程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> DataGrid中嵌套使用Repeater基礎教程

DataGrid中嵌套使用Repeater基礎教程

編輯:關於C#
 

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

 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved