repeater标签双重循环的使用
在网站开发中,.NET中的repeater标签几乎是笔者首选,也是唯一一个不会生成多余元素的标签,所有样式都是自定义的,这点类似 struts中的<s:iterator/>标签。
在日常编码中,有时候希望使用两层repeater嵌套进行绑定数据。
比如笔者希望创建一个如图所示的折叠菜单:

1.编写HTML代码
<!--loop1 start-->
<asp:Repeater ID="rptFirst" runat="server">
<ItemTemplate>
<div class="lsbox">
<div class="lsbar">
<span class="icon1">
第<%#Container.ItemIndex%>次登记
</span>
</div>
<ul class="lslis">
<!--loop2 start-->
<asp:Repeater ID="rptSecond" runat="server">
<ItemTemplate>
<li><a href='#'><%#Eval("YName") %></a></li>
</ItemTemplate>
</asp:Repeater>
<!--loop2 end-->
</ul>
</div>
</ItemTemplate>
</asp:Repeater>
<!--loop1 end-->
代码经过笔者简化,如上面所示。rptFirst绑定父节点菜单,rptSecond绑定子节点菜单。
//绑定父菜单数据
rptFirst.DataSource = list;
rptFirst.DataBind();
//循环父菜单个数
for (int i = ; i < list.Count; i++)
{
参数 = list[i];
//查找内层repeater标签
Repeater rptSecond= this.rptFirst.Controls[i].FindControl("rptSecond") as Repeater;
//根据外层标签参数获取子标签集合
IList<Floor> flist = 子循环集合[参数来源外层标签];
//绑定子菜单数据
rptSecond.DataSource = flist;
rptSecond.DataBind();
}
这样,数据就成功绑定了。(注意:如果当前页面使用了母板页,内层循环无法绑定到数据。)
2.双重循环中的索引
A.在第一层循环中获取外层索引:<%#Container.ItemIndex%>
B.在第二层循环中获取外层索引:此时使用<%#Container.ItemIndex%>获取的是内层的索引,所以我们使用javascript变量作为临时存储,此时声明的i是局部变量,可以在循环中使用:
<script>
var i = <%#Container.ItemIndex %>;
</script>
在内层循环中需要使用的地方输出变量:<script>document.write("<ul class='databody bg"+i+"'>");</script>
3.如果想在repeater中倒叙索引值,可以这样(这种情况很少见)
<script type="text/javascript">
var i=<%#Container.ItemIndex %>;//获取当前索引
var total = <%=rptFirst.Items.Count %>;//获取总循环数(使用表达式)
document.write(total-i);//输出
</script>
默认获取的索引是从0开始递增,如果希望获取递减的索引值,如上所示使用javascript。
===================================================================
4.在使用了母板的内容页中双层嵌套时。
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" Runat="Server">
<div id="leftslide">
<div class="bk40"></div>
<div class="bk10"></div>
<div class="icon-house"><%=groupName %></div>
<!--loop1 start-->
<asp:Repeater ID="rptXkz" runat="server">
<ItemTemplate>
<div class="lsbox">
<div class="lsbar">
<span class="icon1">第
<script type="text/javascript">
var i=<%#Container.ItemIndex %>;
var total = <%=rptXkz.Items.Count %>
document.write(total-i);
</script>
次备案(<%#Eval("Y_YouXiaoQi") %>)</span></div>
<ul class="lslis">
<!--loop2 start-->
<asp:Repeater ID="rptFloor" runat="server">
<ItemTemplate>
<li yno="<%#Eval("YNO") %>"><a href='fangjiaNew.aspx?yid=<%#Eval("XF_YSXKZId") %>&yno=<%#Eval("YNO") %>'><%#Eval("YName") %></a>
<asp:Label ID="lblTao" runat="server" Text=""></asp:Label></li>
</ItemTemplate>
</asp:Repeater>
<!--loop2 end-->
</ul>
</div>
</ItemTemplate>
</asp:Repeater>
<!--loop1 end-->
</div>
仍然可以找到rptFloor控件
//左边树菜单
private void LoadTreeInfo()
{
IList<XF_YSXKZ> list = XF_YSXKZService.QueryByXiangMuGroup(groupName);
rptXkz.DataSource = list;
rptXkz.DataBind();
for (int i = ; i < list.Count; i++)
{
XF_YSXKZ xkz = list[i];
int xkzID = xkz.YID;
Repeater rptFloor = this.rptXkz.Controls[i].FindControl("rptFloor") as Repeater;
IList<XF_Floor> flist = XF_FloorService.QueryFloorByXkzID(xkzID);
rptFloor.DataSource = flist;
rptFloor.DataBind();
for (int j = ; j < flist.Count; j++)
{
Label lbl = rptFloor.Controls[j].FindControl("lblTao") as Label;
XF_Floor xf = flist[j];
int total = XF_FangService.QueryCountByGroupNameAndYNO(groupName, xf.YNO);
int leave = XF_FangService.QueryCountByGroupNameAndYNOAndXState(groupName, xf.YNO, " #006600");
lbl.Text = "剩" + leave + "套/共" + total + "套";
}
}
}
但是如果母板页使用了字段绑定 在pageload中调用了这个方法:this.DataBind();
那无论内容页如何绑定rptFloor都无法得到值。
如:母板页使用了全局变量 public NewFloor Floor{}
然后在页面上这样绑定 <%#Floor.NF_Name %> 注意这里使用的#符号 所以需要调用this.DataBind()绑定数据。
也就是说:(母板页中的this.DataBind()方法会导致 内容页中双层嵌套的内层repeater绑定数据无效)
我们将上面的 # 改成 = 如:<%=Floor.NF_Name %> 然后删除this.DataBind(); 这样内容页中的rptFloor控件就可以正常得到数据了。
此问题困扰我3-4个小时,最后通过删除母板逐句排除才找到原因,希望对大家有用。
repeater标签双重循环的使用的更多相关文章
- java08双重循环打印图形
// 九九乘法表 外层循环每执行一次,内层循环执行一遍 for (int i = 1; i <= 9; i++) { // 外层控制的是行数 for (int j = 1; j <= i; ...
- 带标签的循环语句、switch
今天继续更新,控制流程的剩余部分内容,带标签的循环语句中的continue/break 的使用方法,以及switch关键字的使用方法.例1:带标签的continue/break.package com ...
- java基础08 双重循环打印图形
public class Double01 { /** * 若有3个班级各4名学员参赛, * 如何计算每个班级参赛学员的平均分? */ public static void main(String[] ...
- Python基础—05-总结:双重循环,数据类型
总结 双重循环 冒泡排序 lt = [1, 5, 7, 3, 2, 4] # 计算元素的个数 n = len(lt) # 外层循环控制圈数 for i in range(n-1): for j in ...
- YTU 2690: 用双重循环实现小九九
2690: 用双重循环实现小九九 时间限制: 1 Sec 内存限制: 128 MB 提交: 848 解决: 573 题目描述 小九九是我们小时候常背的的乘法算术法则,现在用双重循环来实现小九九 1 ...
- vue标签内循环数据逗号分隔
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 输出简单图形(StringBuilder代替双重循环)
在有些题目中打印简单图形必须使用StringBuilder或者StringBuffer,否则会运行超时(用String都会超时). 因为在题目的要求中说到输入的n是小于1000的,用双重循环就会超时, ...
- doT模板双重循环模板渲染方法
doT模板作为一个前端渲染模板,有着非常显著的有点.1.轻量.2.快捷.3.无依赖. 本文介绍一种几乎所有模板都会遇到的问题,双重循环渲染.我们知道在dot模板中循环渲染用的是{{~ it:value ...
- shell脚本———双重循环——九九乘法表
1.基础双重循环模板 2.break跳出单个循环 3.continue中止某次循环中的命令,但不会完全中止整个命令 4.九九乘法表
随机推荐
- JAVA取随机数,石头剪刀布实例
一.取随机数: import java.util.Random; //导入随机数 public class Test{ public static void main(String[] args){ ...
- Bugtags:移动时代首选 Bug 管理系统
Bug 管理系统之重 回想我们每次开启一个新项目,筹备之初,首要之事就是选择一款 Bug 管理系统.市面上有诸多 Bug 管理系统可供选择:Jira.Redmine.Bugzilla 等.这些系统功能 ...
- Bootstrap学习的点点滴滴
1)网站:http://www.bootcss.com/http://v3.bootcss.com/getting-started/#downloadhttps://github.com/twbs/b ...
- 基于Maven的Springboot+Mybatis+Druid+Swagger2+mybatis-generator框架环境搭建
基于Maven的Springboot+Mybatis+Druid+Swagger2+mybatis-generator框架环境搭建 前言 最近做回后台开发,重新抓起以前学过的SSM(Spring+Sp ...
- spring mvc中的json整合
spring mvc整合过程中是有版本兼容的问题.具体的哪个版本的springmvc和哪个个版本的json包冲突我也无从考证了.我用的springmvc版本是3.2.1jaskson的版本是 1.1. ...
- 一些代码 I (斐波那契、for...else...、try和return、classmethod、统计个数)
1. 斐波那契 from itertools import islice def fib(): a, b = 0, 1 while True: yield a a, b = b, a+b print ...
- [ASP.NET]ASP.NET数据绑定菜单控件
public void BindMenu(Menu mn,MenuItem menu,string mainMenu,string sql) { MenuItem mitem = null; DB d ...
- inno setup脚本,涵盖了自定义安装界面,调用dll等等应用
; Script generated by the Inno Setup 脚本向导. ; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETU ...
- (转)C#执行exe程序
本文转自:http://www.cnblogs.com/vir56k/archive/2012/12/03/2799810.html,作者张云飞VIR 最近在操作adb做一些事情,就需要开发个wind ...
- 使用eclipse集成开发环境开发第一个嵌入式Linux驱动
转载学习 http://blog.csdn.net/cp1300/article/details/8266806