<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head> <title>案例代码</title></head><body> <h3>循环输出li列表</h3> <% for (int i = 0; i < 5; i++) { %> <li> 这是第<%=i %>个列表内容 </li> <% } %></body></html>

终极实现的效果就如下所示:

虽然上面的代码可以实现循环输出内容的功能,但是你可以看到html代码和Java代码相互嵌套在一起,可读性较差,并且后面代码越来越多的时候,可掩护性也会变得很差。
为理解决这个问题,提高JSP文件中Java代码的可读性,于是就涌现了JSTL标签库,sun公司将常用的功能代码封装成了一个个指定的类似xml的标签,例如:<c:if>、<c:forEach>等等,并且结合EL表达式获取到数据,进行数据的渲染,终极完玉成部HTML网页的展示。

1.1、<c:forTokens>迭代标签

<c:forTokens>标签比较分外,它是专门针对字符串进行迭代输出的,这个标签可以指定一个分隔符,然后会将字符串按照指定的分隔符拆分成数组进行遍历。
<c:forTokens>标签中的属性和<c:forEach>标签中的属性完备同等,并且<c:forTokens>标签多了一个delims属性,并且这个属性可以指定多个分隔符。
语法格式如下所示:

jsp迭代JSP第17节JSTL标签库之迭代标签介绍 CSS

<%-- items 属性:须要迭代的字符串 delims 属性:将字符串按照指定的分隔符进行拆分,可以指定多个分隔符 begin 属性:从哪个下标开始循环 end 属性:哪个下标结束循环 step 属性:每一次循环的步长 var 属性:当前遍历到的元素变量名称 varStatus 属性:当前遍历到的元素状态; index:可以通过index属性获取到当前元素下标,从0开始; count:通过count属性获取当前第几次循环,从1开始; first:是否第一个元素; last:是否末了一个元素; current:获取当前元素; begin:开始下标; end:结束下标; step:步长;--%><c:forTokens items="${message}" delims=";" begin="0" end="5" step="1" var="item" varStatus="status"> <li>当前元素:${item},下标:${status.index},总数:${status.},是否第一个元素:${status.first},是否末了一个元素:${status.last}</li></c:forTokens>

个中varStatus属性具有下面这些属性值:

下面来看看<c:forTokens>标签的详细案例代码。

1.3、案例代码

<%@ page contentType="text/html;charset=UTF-8" language="java" %><%-- 引入标签库 --%><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %><html><head> <title>JSTL标签库之c:forTokens标签</title></head><body> <% String message = "A;B;C;D;E;F"; pageContext.setAttribute("message", message); %> <h3>JSTL标签库之c:forTokens标签</h3> <h3>c:forTokens迭代标签</h3> <%-- items 属性:须要迭代的字符串 delims 属性:将字符串按照指定的分隔符进行拆分,可以指定多个分隔符 begin 属性:从哪个下标开始循环 end 属性:哪个下标结束循环 step 属性:每一次循环的步长 var 属性:当前遍历到的元素变量名称 varStatus 属性:当前遍历到的元素状态; index:可以通过index属性获取到当前元素下标,从0开始; count:通过count属性获取当前第几次循环,从1开始; first:是否第一个元素; last:是否末了一个元素; current:获取当前元素; begin:开始下标; end:结束下标; step:步长; --%> <c:forTokens items="${message}" delims=";" begin="0" end="5" step="1" var="item" varStatus="status"> <li>当前元素:${item},下标:${status.index},总数:${status.},是否第一个元素:${status.first},是否末了一个元素:${status.last}</li> </c:forTokens></body></html>

运行结果如下所示:

以上,便是<c:forTokens>迭代标签的利用。

本日就到这里,未完待续~~