DataGrid中嵌套使用Repeater
2006-03-03 10:02
483 查看
本文描述了如何把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>
完整的代码 如下,要注意的是,
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>
相关文章推荐
- DataGrid中嵌套使用Repeater
- DataGrid中嵌套使用Repeater
- DataGrid中嵌套使用Repeater
- 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论
- asp.net中Repeater嵌套绑定的方法(使用两个Repeater做子类别绑定)
- 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(转)
- 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(2)
- 使用嵌套 Repeater 控件和 Visual C# .Net 显示分层数据
- Repeater控件嵌套使用
- 如何使用动态创建模板列并绑定数据(GridView,Repeater,DataGrid)
- 关于何种情况下使用DataGrid、DataList或Repeater的一
- Repeater嵌套使用实例
- 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论
- Repeater中嵌套使用Repeater
- datalist,repeater,datagrid嵌套问题,,解决代码,,总结
- 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论
- 决定何时使用 DataGrid、DataList 或 Repeater
- HOW TO:使用嵌套 Repeater 控件和 Visual C# .Net 显示分层数据
- Repeater 控件的嵌套使用
- 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论