[英]Nested Repeater Using DataTable Asp.net
问题是当我使用dt1作为rpt2.DataSource(嵌套中继器源)时,程序运行良好,但是当我使用dt2作为源(并相应地更改Eval())时,输出仅是First Repeater。
dt2的输出=>
1只公羊
2个处理器
3张图形卡
当我为dt1进行更改时输出=>
1只公羊
1个
2
3
2个处理器
1个
2
3
3张图形卡
1个
2
3
<body>
<form id="form1" runat="server">
<div>
<asp:Repeater ID="my_repeater1" runat="server" OnItemDataBound="my_repeater1_ItemDataBound">
<ItemTemplate>
<asp:Label Text='<%#Eval("ID")%>' ID="my_text1" runat="server" />
<asp:Label Text='<%#Eval("CATEGORY")%>' ID="my_text2" runat="server" />
<br />
<asp:Repeater runat="server" ID="my_repeater2">
<ItemTemplate>
<asp:Label Text='<%#Eval("ITEMS")%>' ID="lbl1" runat="server" />
<br />
</ItemTemplate>
</asp:Repeater>
</ItemTemplate>
</asp:Repeater>
</div>
</form>
public partial class WebForm1 : System.Web.UI.Page
{
DataTable dt1 = new DataTable();
DataTable dt2 = new DataTable();
DataTable dt3 = new DataTable();
protected void Page_Load(object sender, EventArgs e)
{
dt1.Columns.Add("ID");
dt1.Columns.Add("CATEGORY");
dt1.Rows.Add("1", "Rams");
dt1.Rows.Add("2", "Processors");
dt1.Rows.Add("3", "GraphicCards");
my_repeater1.DataSource = dt1;
my_repeater1.DataBind();
dt2.Columns.Add("ID");
dt2.Columns.Add("ITEMS");
dt2.Rows.Add("1", "DDR1");
dt2.Rows.Add("2", "DDR2");
dt2.Rows.Add("3", "DDR3");
}
protected void my_repeater1_ItemDataBound(object sender, RepeaterItemEventArgs e)
{
Repeater rpt2 = (Repeater)e.Item.FindControl("my_repeater2");
rpt2.DataSource = dt2;
rpt2.DataBind();
}
}
执行my_repeater1.DataBind()
,.NET将开始构建my_repeater1。 对于添加到my_repeater1的每一行, my_repeater1_ItemDataBound
调用my_repeater1_ItemDataBound
。 并且由于您将dt2用作嵌套中继器的源,因此将不会获得任何数据,因为dt2尚未填充数据。 这仅在my_repeater1的构建完成后才在您的示例中发生。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.