.NET开发

本类阅读TOP10

·NHibernate快速指南(翻译)
·vs.net 2005中文版下载地址收藏
·【小技巧】一个判断session是否过期的小技巧
·VB/ASP 调用 SQL Server 的存储过程
·?dos下编译.net程序找不到csc.exe文件
·通过Web Services上传和下载文件
·学习笔记(补)《.NET框架程序设计(修订版)》--目录
·VB.NET实现DirectDraw9 (2) 动画
·VB.NET实现DirectDraw9 (1) 托管的DDraw
·建站框架规范书之——文件命名

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
DataGrid中嵌套使用Repeater

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

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




相关文章

相关软件