ASP.NET如何把查询出来的数据遍历添加到数组中后,用Repeater显示
我从数据库中查询出一些东西,比如:A超市,商品1A超市,商品2B超市,商品1C超市,商品1C超市,商品2-----------------经过处理后,变成:A超市,商品1...
我从数据库中查询出一些东西,比如:
A超市,商品1
A超市,商品2
B超市,商品1
C超市,商品1
C超市,商品2
-----------------
经过处理后,变成:
A超市,商品1
商品2
B超市,商品1
C超市,商品1
商品2
-------------------
然后绑定在Repeater上。
请问要怎么做?A,B,C超市的个数是不确定的,商品1,2,3的个数也是不确定的。
百分悬赏,完成之后,再送百分! 展开
A超市,商品1
A超市,商品2
B超市,商品1
C超市,商品1
C超市,商品2
-----------------
经过处理后,变成:
A超市,商品1
商品2
B超市,商品1
C超市,商品1
商品2
-------------------
然后绑定在Repeater上。
请问要怎么做?A,B,C超市的个数是不确定的,商品1,2,3的个数也是不确定的。
百分悬赏,完成之后,再送百分! 展开
3个回答
展开全部
这个要用到repeater的嵌套调用,数据是我模拟的,已经测试过了没问题,你可以把这段东西直接放到你的程序里试试
代码如下(注意前台页面的代码中DataSource='<%#GetRows(Eval("c1").ToString()) %>'>这里一定要用单引号)
后台代码
DataTable dt = new DataTable();
protected void Page_Load(object sender, EventArgs e)
{
dt.Columns.Add("c1");
dt.Columns.Add("c2");
DataRow dr = dt.NewRow();
dr["c1"] = "A超市";
dr["c2"] = "商品1";
dt.Rows.Add(dr);
DataRow dr2 = dt.NewRow();
dr2["c1"] = "A超市";
dr2["c2"] = "商品2";
dt.Rows.Add(dr2);
DataRow dr3 = dt.NewRow();
dr3["c1"] = "B超市";
dr3["c2"] = "商品1";
dt.Rows.Add(dr3);
DataRow dr4 = dt.NewRow();
dr4["c1"] = "B超市";
dr4["c2"] = "商品2";
dt.Rows.Add(dr4);
this.List1.DataSource = dt;
this.List1.DataBind();
}
protected DataTable GetRows(string chaoshi)
{
DataTable dt2 = dt.Clone();
DataRow[] rows = dt.Select("c1='" + chaoshi + "'");
for (int i = 0; i < rows.Length; i++)
{
dt2.ImportRow(rows[i]);
}
return dt2;
}
前台代码
<table>
<asp:Repeater ID="List1" runat="server">
<ItemTemplate>
<tr>
<td><%#Eval("c1") %></td>
<td>
<table>
<asp:Repeater ID="List2" runat="server" DataSource='<%#GetRows(Eval("c1").ToString()) %>'>
<ItemTemplate>
<tr><td><%#Eval("c2")%></td></tr>
</ItemTemplate>
</asp:Repeater>
</table>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
</table>
代码如下(注意前台页面的代码中DataSource='<%#GetRows(Eval("c1").ToString()) %>'>这里一定要用单引号)
后台代码
DataTable dt = new DataTable();
protected void Page_Load(object sender, EventArgs e)
{
dt.Columns.Add("c1");
dt.Columns.Add("c2");
DataRow dr = dt.NewRow();
dr["c1"] = "A超市";
dr["c2"] = "商品1";
dt.Rows.Add(dr);
DataRow dr2 = dt.NewRow();
dr2["c1"] = "A超市";
dr2["c2"] = "商品2";
dt.Rows.Add(dr2);
DataRow dr3 = dt.NewRow();
dr3["c1"] = "B超市";
dr3["c2"] = "商品1";
dt.Rows.Add(dr3);
DataRow dr4 = dt.NewRow();
dr4["c1"] = "B超市";
dr4["c2"] = "商品2";
dt.Rows.Add(dr4);
this.List1.DataSource = dt;
this.List1.DataBind();
}
protected DataTable GetRows(string chaoshi)
{
DataTable dt2 = dt.Clone();
DataRow[] rows = dt.Select("c1='" + chaoshi + "'");
for (int i = 0; i < rows.Length; i++)
{
dt2.ImportRow(rows[i]);
}
return dt2;
}
前台代码
<table>
<asp:Repeater ID="List1" runat="server">
<ItemTemplate>
<tr>
<td><%#Eval("c1") %></td>
<td>
<table>
<asp:Repeater ID="List2" runat="server" DataSource='<%#GetRows(Eval("c1").ToString()) %>'>
<ItemTemplate>
<tr><td><%#Eval("c2")%></td></tr>
</ItemTemplate>
</asp:Repeater>
</table>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
</table>
2012-05-03
展开全部
分2次绑定。一次绑定超市,二次绑定商品。用Repeater嵌套Reapeater
更多追问追答
追问
能不能给个Demo或者贴下代码,我Repeater不熟,只会简单的数据绑定。嵌套也不是太会。但是我能理解你的思想是什么意思。能不能说说具体怎么实现?
从数据查询开始,谢谢了!
追答
给个邮箱给你发个Demo
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询