迭代操作-->c:forEach和c:forTokens
jstl--->Core 核心标签库-->c:forEach
在页面上遍历后台传到前台的数据是最基本的最常用的方法 主要包含两种迭代操作:forEach和forTokens
语法1:迭代集合所有事物
<c:forEach [var="varName"] items="collection" [varStatus="varStatusName"] [begin="begin"] [end="end"] [step="step"]> </c:forEach>
语法2:迭代指定的次数
<c:forEach [var="varName"] [varStatus="varStatusName"] begin="begin" end="end" [step="step"]> </c:forEach>
属性:
var ---> 存放当前成员
items ---> 被迭代的集合
varStatus ---> 存放当前对象相关咨询
begin ---> 开始的位置
end ---> 结束的位置
step --->每次迭代的间隔数
举个栗子:
1、循环遍历,输出所有的元素。
<c:foreach items="${list}" var="li">
${li}
</c:foreach>
--->items 用于接收集合对象,var 定义对象接收从集合里遍历出的每一个元素。同时其会自动转型。
2、循环遍历,输出一个范围类的元素。 <c:foreach items ="${lis}" var = "li " begin="2" end ="12"> ${li} </c:foreach>
--->begin 定义遍历的开始位置,end定义遍历的结束位置。begin 和end的引号必须写。
3、循环遍历,输出除某个元素以外的元素或输出指定元素。
<c:foreach items="${list}" var ="li" varStatus="status"> <c:if text="${status.count==1}> ${"第一个元素不要"} </c:if> ${li} </ c:foreach>
--->varStatus 表示当前集合的状态,count为循环一个计算器。
4、循环遍历,输出第一个或最后一个元素。
<c:foreach items="${list}" var ="li" varStatus="status">
<c:if text="${status.first}">我是第一个元素</c:if>
c:if text="${status.last}">我是最后一个元素</c:if>
</c:foreach>
--->first表示如果是一个元素,则返回ture,反之则返回false last 表示如果是最后一个元素,则返回ture,反之则返回false。
5、循环遍历,按指定步长输出。
<c:forEach items="${atts}" var="item" begin="1" end="4" step="2" > ${item}</br> </c:forEach>
-->表示从集合1-4每隔2个打印出来(1,3);
<c:forEach items="${atts}" var="item" begin="4" end="10" step="4" > ${item}</br> </c:forEach>
-->表示从集合4-10每隔4个打印出来(4,8);
注:c:forEach并不只是用来浏览集合而已,items并不是一定要有的属性,但是当没有使用items时就必须要有 begin和end两个属性,
举个栗子: <c:forEach begin="1" end="10" var="item" > ${item}</br> </c:forEach>
只有设定begin和end值它既变成一个简单的集合,他将1-10赋值给item
varStatus ---> 他有四个属性:
index:当前成员的索引
count:但目前为止当前成员的总数
first:当前成员是否是第一个
last:当前成员是否是最后一个
例: <c:forEach items="${atts}" var="item" varStatus="s"> <h2><c:out value="${item}"/> </h2> index ${s.index}</br> count ${s.count}</br> first ${s.first}</br> last ${s.last}</br> </c:forEach>
jstl--->Core 核心标签库-->c:forTokens>
用来浏览一组字符串的所有成员,由定义符号(delimiters)所分割
语法: <c:forTokens items="stringOfTokens" delims="delimiters" [var="varName"] [varStatus="varStatusName"] [begin="begin"] [end="end"] [step="step"]> </c:forTokens>
属性:
var: 存放当前知道的成员
items: 被迭代的字符串
delims: 定义用来分割字串的字元
varsttus: 存放当前对象相关咨询
begin: 开始的位置
end: 结束的位置
step: 每次迭代的间隔数
-->与forEach的区别在于items和delims这两个属性,items必须为字符串,而delims作为分隔符
举几个栗子:
<c:forTokens items="A,B,C,D,E" delims="," var="item" > ${item} </c:forTokens>
页面会输出ABCDE,也就是说字符串被","分割为五部分,并执行了五次轮换,但是逗号没有别打印出来
<c:forEach items="A,B,C,D,E" var="item" > ${item} </c:forEach>
然而我们用c:forEach也能达到目的,区别在于c:Tokens的delims不止能指定一种字元来分割,可以有多种
<c:forTokens items="A,B;C-D,E" delims=",;-" var="item" > ${item} </c:forTokens>
用了三种分割符,所以如果使用c:forTokens来分割字符串,功能和弹性会比c:forEach来的较大
迭代操作-->c:forEach和c:forTokens的更多相关文章
- [jstl] forEach标签使用
在JSP的开发中,迭代是经常要使用到的操作.例如,逐行的显示查询的结果等.在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出.现在,通过JS ...
- JSP 基础之 JSTL <c:forEach>用法
在JSP的开发中,迭代是经常要使用到的操作.例如,逐行的显示查询的结果等.在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出.现在,通过JST ...
- jstl中<c:forEach>的用法
在JSP的开发中,迭代是经常要使用到的操作.例如,逐行的显示查询的结果等.在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出.现在,通过JST ...
- [Java] JSP笔记 - EL、JSTL 常用标签
一. 什么是 EL 语言 表达式语言(EL)是 JSP 2.0 引入的一种计算和输出 Java 对象的简单语言. 二.EL 语言的作用 为了使JSP写起来更加简单.表达式语言的灵感来自于 ECMASc ...
- EL和JSTL专题
EL简介 EL全名为Expression Language,它原本是JSTL 1.0为方便存取数据所自定义的语言.当时只能在JSTL标签中使用,如下: <c:out value="${ ...
- Java Servlet(十):JSTL核心标签库
JSTL全名称:JaveServer Pages Standard Tag Library.JSTL是由JCP(Java Community Process)所定制的标准规范,它主要提供给Java W ...
- JSTL标签用法 详解
在JSP的开发中,迭代是经常要使用到的操作.例如,逐行的显示查询的结果等.在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出.现在,通过JST ...
- 20160331javaweb之JSP 标签技术
jsp的标签技术:在jsp页面中最好不要出现java代码,这时我们可以使用标签技术将java代码替换成标签来表示 1.jsp标签:sun原生提供的标签直接在jsp页面中就可以使用 <jsp:in ...
- JSEL 表达式
JSTL标签库的使用是为类弥补html表的不足,规范自定义标签的使用而诞生的.在告别modle1模式开发应用程序后,人们开始注重软件的分层设计,不希望在jsp页面中出现java逻辑代码,同时也由于自定 ...
随机推荐
- LINUX 软件管理
dpkg 安装 dpkg -i package.deb 卸载 dpkg -r packagename 彻底卸载 dpkg -P packagename apt-get 搜查包 apt-cache se ...
- 谈一谈原生JS中的【面向对象思想】
[重点提前说:面向对象的思想很重要!] 最近开始接触学习后台的PHP语言,在接触到PHP中的面向对象相关思想之后,突然想到之前曾接触的JS中的面向对象思想,无奈记性太差, ...
- Spring + Fastweixin 微信开发
这篇文章转自<http://www.qtdebug.com/spring-weixin/> 微信有两种模式,编辑模式和开发者模式,有些功能是互斥的,不可以同时使用,微信开发需要在开发者模式 ...
- 编译错误:expected an indented block
python 对缩进要求非常严格,当运行时出现以下几种情况时,就需要修改缩进: 1.expected an indented block 直接缩进4个space空格或者一个tab.
- 阿里巴巴Java开发手册思维导图
趁着有时间把阿里巴巴Java开发手册又看了一遍了,很多时候觉得看完之后,发现自己好像一点都不记得了里面的内容了.只能把大概内容画一遍在脑子里形成一张图方便记忆,这样就更能够记得自己的看完的内容了.其中 ...
- Here We Go(relians) Again
Here We Go(relians) Again Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/O ...
- awk巩固练习题
第1章 awk数组练习题 1.1 文件内容(仅第一行) [root@znix test]# head -1 secure-20161219 access.log ==> secure-20161 ...
- Tomcat降权启动
对于任何降权的操作都是为了更好的保护自己的服务器免受危害,所以我们使用Tomcat也不了外,也需要进行降权操作.因为当 Tomcat以系统管理员身份或作为系统服务运行时,Java运行时取得了系统用户或 ...
- HTML学习笔记 CSS背景样式案例 第六节 (原创) 参考使用表
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 使用TP5创建一个REST API
原文在这里 : http://hmw.iteye.com/blog/1190827 tp自带的api,get请求接口 /** * 显示资源列表 * * @return \think\Response ...