JSTL标签库的基本教程之核心标签库(二)
- 核心标签库
标签 |
描述 |
用于在JSP中显示数据,就像<%= ... > |
|
用于保存数据 |
|
用于删除数据 |
|
用来处理产生错误的异常状况,并且将错误信息储存起来 |
|
与我们在一般程序中用的if一样 |
|
本身只当做<c:when>和<c:otherwise>的父标签 |
|
<c:choose>的子标签,用来判断条件是否成立 |
|
<c:choose>的子标签,接在<c:when>标签后,当<c:when>标签判断为false时被执行 |
|
检索一个绝对或相对 URL,然后将其内容暴露给页面 |
|
基础迭代标签,接受多种集合类型 |
|
根据指定的分隔符来分隔内容并迭代输出 |
|
用来给包含或重定向的页面传递参数 |
|
重定向至一个新的URL. |
|
使用可选的查询参数来创造一个URL |
核心库标签的分类(上海尚学堂Java培训原创,转载说明出处,陆续有Java相关技术文章奉献)
u 表达式类:out、set、remove、catch
u 逻辑控制类:if、choose、when、otherwise
u 循环判断类:forEach、forTokens
u URL操作类:import、url、redirect、param
在上篇文章中,我们讲了JSTL的核心标签库的表达式类标签:out标签、set标签、remove标签、catch标签。那么我们接下来说一说逻辑控制类标签以及循环判断类标签。
² 逻辑控制类标签
l if标签(单一的if判断,没有else)
属性 |
描述 |
EL支持 |
是否必须 |
默认值 |
test |
判断条件 |
支持 |
是 |
无 |
var |
判断结果存储的变量名 |
不支持 |
否 |
无 |
scope |
变量的存储范围 |
不支持 |
否 |
page |
语法:
<c:if test="testCondition" [var="varName"] [scope="{page|request|session|application}"]> 条件成立时的输出内容 </c:if> |
示例:
<c:set var="name" value="lisa"></c:set> <!-- 当条件成立时,输出:我是lisa --> <c:if test="${name=='lisa'}" var="var1" scope="page">我是lisa</c:if> <!-- 当条件不成立时,不输出 --> <c:if test="${name=='tony'}" var="var2">tony也是lisa</c:if> var1:${var1} -- var2:${var2} <!-- 我是lisa var1:true -- var2:false --> |
l choose、when、otherwise标签(嵌套使用相当于if-elseif-else)
属性 |
描述 |
EL支持 |
是否必须 |
默认值 |
test |
判断条件 |
支持 |
是 |
无 |
语法:
<c:choose> <c:when test=""> 前面的条件都不成立但此条件成立时输出 </c:when> <c:when test=""> 前面的条件都不成立但此条件成立时输出 </c:when> ...... <c:otherwise> 前面的条件都不成立时才输出 </c:otherwise> </c:choose> |
示例:
<c:set var="score" value="60"></c:set> <c:choose> <!-- 不满足条件,不输出 --> <c:when test="${score < 60}"> 不及格 </c:when> <!-- 满足条件,输出 --> <c:when test="${score == 60}"> 刚好及格 </c:when> <!-- 不满足条件,不输出 --> <c:when test="${score > 60}"> 良好 </c:when> <!-- 上面有条件成立,不输出 --> <c:otherwise> 取消资格 </c:otherwise> </c:choose> <!-- 刚好 --> |
² 循环判断类标签
l forEach标签(循环遍历)
forEach参数说明
名称 |
描述 |
EL支持 |
是否必须 |
默认值 |
items |
遍历的集合对象 |
支持 |
否 |
无 |
var |
每次遍历的对象 |
不支持 |
否 |
无 |
varStatus |
遍历的相关信息 |
不支持 |
否 |
无 |
begin |
开始的位置(正数) |
支持 |
否 |
0 |
end |
结束的位置(正数) |
支持 |
否 |
集合长度 |
step |
遍历的步长(正数) |
支持 |
否 |
1 |
varStatus属性说明
名称 |
类型 |
说明 |
index |
number |
遍历对象的索引,从0开始 |
Count |
number |
总共循环的次数,从1开始 |
First |
boolean |
本次循环遍历的是否是集合的第一个元素 |
end |
boolean |
本次循环遍历的是否是集合的最后一个元素 |
语法1:遍历集合,类似(String s:new String[]{“a”,”b”})
<c:forEach items="collection" [var="varName"] [varStatus="varStatusName"] [begin="begin"] [end="end"] [step="step"]> 输出内容 </c:forEach> |
语法2:循环指定次数,类似(int i=0;i<5;i++)
<c:forEach [var="varName"] [varStatus="varStatusName"] begin="begin" end="end" [step="step"]> 输出内容 </c:forEach> |
示例:
循环List
<% List<String> list = new ArrayList<String>(); list.add("A"); list.add("B"); list.add("C"); list.add("D"); list.add("E"); list.add("F"); request.setAttribute("list",list); %> <c:forEach items="${list}" var="l" varStatus="ll" begin="1" end="5" step="2"> 第${ll.count}次迭代,索引:${ll.index},值是:${l},是否是第1个:${ll.first},是否是最后 一个:${ll.last}<br> </c:forEach> <!-- 第1次迭代,索引:1,值是:B,是否是第1个:true,是否是最后 一个:false 第2次迭代,索引:3,值是:D,是否是第1个:false,是否是最后 一个:false 第3次迭代,索引:5,值是:F,是否是第1个:false,是否是最后 一个:true --> |
遍历Map
<% Map<String,String> map = new HashMap<String,String>(); map.put("key1", "value1"); map.put("key2", "value2"); map.put("key3", "value3"); request.setAttribute("map",map); %> <c:forEach items="${map}" var="m"> key:${m.key},value:${m.value}<br> </c:forEach> <!-- key:key3,value:value3 key:key2,value:value2 key:key1,value:value1 --> |
遍历Set
<% Set<String> set = new HashSet<String>(); set.add("周杰伦"); set.add("林俊杰"); set.add("陈奕迅"); request.setAttribute("set",set); %> <c:forEach items="${set}" var="s"> ${s} </c:forEach> <!-- 陈奕迅 林俊杰 周杰伦 --> |
循环指定次数
<c:forEach var="i" varStatus="ii" begin="0" end="10" step="3"> 第${ii.count}次迭代,索引:${ii.index},值是:${i},是否是第1个:${ii.first},是否是最后 一个:${ii.last}<br> </c:forEach> <!-- 第1次迭代,索引:0,值是:0,是否是第1个:true,是否是最后 一个:false 第2次迭代,索引:3,值是:3,是否是第1个:false,是否是最后 一个:false 第3次迭代,索引:6,值是:6,是否是第1个:false,是否是最后 一个:false 第4次迭代,索引:9,值是:9,是否是第1个:false,是否是最后 一个:true --> |
l forTokens标签(字符串拆分,相当于String的split方法)
名称 |
描述 |
EL支持 |
是否必须 |
默认值 |
items |
要被拆分的字符串 |
支持 |
是 |
无 |
delims |
用来拆分的字符串 |
不支持 |
是 |
无 |
var |
保存每次拆分的字符串 |
不支持 |
否 |
无 |
varStatus |
第几次拆分的相关信息 |
不支持 |
否 |
无 |
begin |
起始位置 |
支持 |
否 |
0 |
end |
终止位置 |
支持 |
否 |
被拆分后的长度 |
step |
步长 |
支持 |
否 |
1 |
语法:
<c:forTokens items="str" delims="selStr" [var="varName"] [varStatus="varStatusName"] [begin="begin"] [end="end"] [step="step"]> 输出内容 </c:forTokens> |
注:var、varStatus、begin、end、step和forEach的参数作用相同
示例:
<c:forTokens items="我,很,喜,欢,你" delims="," var="i" varStatus="a"> ${i} </c:forTokens> <!-- 我 很 喜 欢 你 --> |