求.net里repeater嵌套使用的完整代码
求.net里repeater嵌套使用的完整代码,直接就能用的,(最好为非代码后置模式)用来做产品的二级的分级目录的!包括前台和后台的完整代码,总之越完整越好,拿来就能用的...
求.net里repeater嵌套使用的完整代码,直接就能用的,(最好为非代码后置模式)用来做产品的二级的分级目录的!包括前台和后台的完整代码,总之越完整越好,拿来就能用的,,谢谢大家了。。
最佳答案追 加50分
要非代码后置的.net程序。前台后台代码完整的!谢谢大家了! 展开
最佳答案追 加50分
要非代码后置的.net程序。前台后台代码完整的!谢谢大家了! 展开
3个回答
展开全部
把两个表的数据都读出来,建立两个表的关系
ds.Relation.Add();
然后在父Repeater的ItemDataBind事件中找到子Repeater
在根据关系找到子Repeater对应的数据源,绑定上ok。
页面上:
<asp:Repeater id="Repeater1" runat="server">
<HeaderTemplate>
<table width="500">
<tr bgcolor=blue>
<td>用户留言显示</td>
</tr>
</HeaderTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
<ItemTemplate>
<tr bgcolor=aaaaaa>
<td>用户名:<%#DataBinder.Eval(Container.DataItem,"username")%></td>
</tr>
<tr>
<td>用户留言的显示</td>
</tr>
<tr>
<td><asp:Repeater id="Repeater2" runat="server">
<ItemTemplate>
留言信息<%#DataBinder.Eval(Container.DataItem,"content")%><br>
</ItemTemplate>
</asp:Repeater></td>
</tr>
</ItemTemplate>
</asp:Repeater>
cs代码:
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
namespace AdoDotNet_Demo
{
/// <summary>
/// RepeaterLink1 的摘要说明。
/// </summary>
public class RepeaterLink1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Repeater Repeater2;
protected System.Web.UI.WebControls.Repeater Repeater1;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
if(!Page.IsPostBack)
{
string strconn = "server=.;uid=sa; pwd=;database=myweb";
SqlConnection conn = new SqlConnection(strconn);
SqlDataAdapter da = new SqlDataAdapter("select * from userinfo",conn);
DataSet ds = new DataSet();
da.Fill(ds,"user");
SqlDataAdapter da1 = new SqlDataAdapter("select * from content",conn);
da1.Fill(ds,"content");
ds.Relations.Add("relation1",ds.Tables["user"].Columns["UserName"],ds.Tables["content"].Columns["UserName"]);
Repeater1.DataSource = ds.Tables["user"];
Repeater1.DataBind();
}
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Repeater1.ItemDataBound += new System.Web.UI.WebControls.RepeaterItemEventHandler(this.Repeater1_ItemDataBound);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void Repeater1_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
{
if(e.Item.ItemType == ListItemType.Item)
{
//repeater1行数据获得到
DataRowView drv = (DataRowView)e.Item.DataItem;
DataView dv = drv.CreateChildView("relation1");
//根据行数据得到repeater2的数据源
//找到当前行中repeater2
System.Web.UI.WebControls.Repeater r = (System.Web.UI.WebControls.Repeater)e.Item.FindControl("Repeater2");
r.DataSource = dv;
r.DataBind();
}
}
}
}
ds.Relation.Add();
然后在父Repeater的ItemDataBind事件中找到子Repeater
在根据关系找到子Repeater对应的数据源,绑定上ok。
页面上:
<asp:Repeater id="Repeater1" runat="server">
<HeaderTemplate>
<table width="500">
<tr bgcolor=blue>
<td>用户留言显示</td>
</tr>
</HeaderTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
<ItemTemplate>
<tr bgcolor=aaaaaa>
<td>用户名:<%#DataBinder.Eval(Container.DataItem,"username")%></td>
</tr>
<tr>
<td>用户留言的显示</td>
</tr>
<tr>
<td><asp:Repeater id="Repeater2" runat="server">
<ItemTemplate>
留言信息<%#DataBinder.Eval(Container.DataItem,"content")%><br>
</ItemTemplate>
</asp:Repeater></td>
</tr>
</ItemTemplate>
</asp:Repeater>
cs代码:
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
namespace AdoDotNet_Demo
{
/// <summary>
/// RepeaterLink1 的摘要说明。
/// </summary>
public class RepeaterLink1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Repeater Repeater2;
protected System.Web.UI.WebControls.Repeater Repeater1;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
if(!Page.IsPostBack)
{
string strconn = "server=.;uid=sa; pwd=;database=myweb";
SqlConnection conn = new SqlConnection(strconn);
SqlDataAdapter da = new SqlDataAdapter("select * from userinfo",conn);
DataSet ds = new DataSet();
da.Fill(ds,"user");
SqlDataAdapter da1 = new SqlDataAdapter("select * from content",conn);
da1.Fill(ds,"content");
ds.Relations.Add("relation1",ds.Tables["user"].Columns["UserName"],ds.Tables["content"].Columns["UserName"]);
Repeater1.DataSource = ds.Tables["user"];
Repeater1.DataBind();
}
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Repeater1.ItemDataBound += new System.Web.UI.WebControls.RepeaterItemEventHandler(this.Repeater1_ItemDataBound);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void Repeater1_ItemDataBound(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
{
if(e.Item.ItemType == ListItemType.Item)
{
//repeater1行数据获得到
DataRowView drv = (DataRowView)e.Item.DataItem;
DataView dv = drv.CreateChildView("relation1");
//根据行数据得到repeater2的数据源
//找到当前行中repeater2
System.Web.UI.WebControls.Repeater r = (System.Web.UI.WebControls.Repeater)e.Item.FindControl("Repeater2");
r.DataSource = dv;
r.DataBind();
}
}
}
}
展开全部
后台.cs程序:
protected void objectiveCategory2_ItemDataBound
(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
{ DataView dv = new DataView(this.dtCategory);
dv.RowFilter = "eloc_iparentid=" + this.dtCategory.Rows[e.Item.ItemIndex]["eloc_iparentid"].
ToString();
Repeater tempRepeater = (Repeater)e.Item.FindControl("elo_sdescription");
tempRepeater.DataSource = dv; tempRepeater.DataBind(); }
注意:其中第2层的 OnItemDataBound="objectiveCategory2_ItemDataBound 是重要部分,因为里层的repeater web里是认识不到的,只有在这指明了事件处理方法,才能触发后台程序里的方法。类似的也可以用这种方法多层嵌套,并能处理里面的事件。
第二点在 aspx 指明事件的在后台程序,需要protected 来限定访问限制,如用private 就会出现限制访问的错误提示。
protected void objectiveCategory2_ItemDataBound
(object sender, System.Web.UI.WebControls.RepeaterItemEventArgs e)
{ DataView dv = new DataView(this.dtCategory);
dv.RowFilter = "eloc_iparentid=" + this.dtCategory.Rows[e.Item.ItemIndex]["eloc_iparentid"].
ToString();
Repeater tempRepeater = (Repeater)e.Item.FindControl("elo_sdescription");
tempRepeater.DataSource = dv; tempRepeater.DataBind(); }
注意:其中第2层的 OnItemDataBound="objectiveCategory2_ItemDataBound 是重要部分,因为里层的repeater web里是认识不到的,只有在这指明了事件处理方法,才能触发后台程序里的方法。类似的也可以用这种方法多层嵌套,并能处理里面的事件。
第二点在 aspx 指明事件的在后台程序,需要protected 来限定访问限制,如用private 就会出现限制访问的错误提示。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
谢谢两位的回答,有没有非代码后置模式的源代码啊。。这种程序不好引用啊。。麻烦高手帮忙解答一下。。最佳答案一定加分
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询