JSTL 核心标签库

JSTL核心标签库包含了一组用于实现WEB应用中的通用操作的标签,JSP规范为核心标签库建议的前缀名为c

8.3.1  <c:out>标签

<c:out> 标签用于输出一段文本内容到pageContext对象当前保存的“out”对象中,在通常情况下,pageContext对象当前保存的“out”对象的数据是输出到客户端浏览器,所以,<c:out> 标签通常用于输出一段文本内容到客户端浏览器。如果<c:out> 标签输出的文本内容中包含了需要进行转义的HTML特殊字符,例如,<>'"&等,<c:out> 标签默认对它们按表8.2进行HTML编码转换后再进行输出,这样就可以在浏览器中显示出这些字符。

8.2 特殊字符转换

<c:out>标签标签有两种语法格式:

语法1,没有标签体的情况:

<c:out value="value"

    [escapeXml="{true|false}"]

   [default="defaultValue"] />

语法2,有标签体的情况,在标签体中指定输出的默认值:

<c:out value="value"

   [escapeXml="{true|false}"] >

default value

</c:out>

<c:out>标签的属性说明如表8.3所示。

8.3  <c:out>标签的属性

属性名

是否支持EL

属性类型

value

true

Object

指定要输出的内容

escapeXml

true

Boolean

指定是否将><&'" 等特殊字符进行HTML编码转换后再进行输出。默认值为true

default

true

Object

指定如果value属性的值为null时所输出的默认值

 

当且仅当value属性的值为null时,<c:out> 标签输出默认值;如果没有指定默认值,默认为空字符串。<c:out> 标签的标签体的内容用于指定输出的默认值,如果value属性的值不为null,即使标签体部分不为空,标签体的内容也不会被输出。如果value属性不是指向一个java.io.Reader对象,<c:out> 标签将调用这个对象的toString方法,然后输出获得的字符串内容。如果value属性指向一个java.io.Reader对象,<c:out> 标签将从这个Reader对象中读取数据后进行输出,当有大量数据要被输出时,将这些数据以Reader对象的形式提供给<c:out>标签进行输出,将会极大提高系统性能。当采用escapeXml属性的默认设置值true时,<c:out>标签将对要输出的特殊字符按表8.2进行转换;如果将escapeXml属性设置为false<c:out>标签将不对要输出的特殊字符进行转换,而是直接输出这些特殊字符。

例程8-3<c:out> 标签的一个演示例子程序。

例程8-3  c_out1.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<%

session.setAttribute("test_session", "testValue_session");

%>

直接输出一个字符串:

<c:out value="test" default="123456" /><br /><hr />

输出Web域中不存在的属性的值:<br />

<c:out value="${test_request}" default="这个属性不存在"/><br /><hr />

输出Web域中的test_session属性的值:<br />

<c:out value="${test_session}" />

 


例程8-3的运行结果如图8.1所示。

8.1

例程8-4和例程8-5是两个用于演示<c:out>标签的escapeXml属性的例子程序,例程8-4没有设置escapeXml属性,例程8-5escapeXml属性设置为了false

例程8-4  c_out2.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<c:out value="${null}" >

<meta http-equiv="refresh" content="0;url=http://www.it315.org" />

</c:out>

 


例程8-5 c_out3.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<c:out value="${null}" escapeXml="false">

<meta http-equiv="refresh" content="0;url=http://www.it315.org" />

</c:out>

 


例程8-4和例程8-5的运行结果分别如图8.2和图8.3所示。

8.2

8.3

8.3.2  <c:set>标签

<c:set>标签用于设置各种Web域中的属性,或者设置Web域中的java.util.Map类型的属性对象或JavaBean类型的属性对象的属性。<c:set>标签有四种语法格式:

语法1,使用value属性设置指定域中的某个属性的值:

<c:set value="value"

    var="varName"

    [scope="{page|request|session|application}"] />

语法2,在标签体中设置指定域中的某个属性的值:

<c:set var="varName"

    [scope="{page|request|session|application}"]>

body content

</c:set>

语法3,使用value属性设置Web域中的一个属性对象的某个属性:

<c:set value="value"

    target="target"

    property="propertyName" />

语法4,在标签体中设置Web域中的一个属性对象的某个属性性:

<c:set target="target"

    property="propertyName">

body content

</c:set>

<c:set>标签的属性说明如表8.4所示。

8.4 <c:set>标签的属性

属性名

是否支持EL

属性类型

value

true

Object

用于指定属性值

var

false

String

用于指定要设置的Web域属性的名称

scope

false

String

用于指定属性所在的Web

target

true

Object

用于指定要设置属性的对象,这个对象必须是JavaBean对象或java.util.Map对象

property

true

string

用于指定当前要为对象设置的属性名称

 

如果使用第1种语法格式时的value属性值为null,或者使用第2种语法格式时的标签体内容为空,<c:set>标签将从scope属性指定的域范围中删除var属性指定的属性。

在第3种语法格式和第4语法格式中,如果target属性的值是java.util.Map对象,property属性表示该Map对象的关键字,如果Map对象没有指定的关键字,就给Map对象增加指定的关键字;如果target属性的值是JavaBean对象,property属性表示JavaBean对象的属性,如果value的类型与JavaBean属性的类型不匹配时,会根据EL的转换规则自动进行转换。当使用第3种语法格式或第4种语法格式时,如果target属性的值为null(即target属性指定的对象不存在),或者target属性的值是一个JavaBean对象,但该JavaBean中不存在property属性指定的属性,<c:set>标签将抛出异常。如果使用第3种语法格式时value属性的值为null,或者使用第4种语法格式时标签体的内容为空,如果target属性的值是一个java.util.Map对象,就从Map对象中删除property属性指定的关键字对应的项;如果target属性的值是一个JavaBean对象,就将JavaBean的相应属性的值设置为null

例程8-6是使用<c:set>标签设置某个Web域中的属性的一个演示例子程序。

例程8-6 c_set1.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<c:set var="userName" scope="session">

zxx

</c:set>

输出session 作用域中的userNamer属性的值:

<c:out value="${userName}" /><br /><hr />

输出session 作用域中的bookname属性的值:

<c:set var="bookname" scope="session" />

<c:out value="${bookname}" />

 


例程8-6运行结果如图8.4所示

8.4

例程8-7是使用<c:set>标签设置UserBean对象和Map对象的属性的一个演示例子程序。

例程8-7  c_set2.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<%@ page import="java.util.HashMap" %>

<jsp:useBean id="user" class="org.it315.UserBean" />

<% 

HashMap preferences = new HashMap();

session.setAttribute("preferences",preferences);

%>

设置和输出UserBean对象的userName属性值:

<c:set value="zxx" target="${user}" property="userName" />

<c:out value="${user.userName}" /><br /><hr />

设置和输出UserBean对象的password属性值:

<c:set target="${user}" property="password" />

<c:out value="${user.password}" /><br /><hr />

设置和输出Map对象的color关键字的值:

<c:set target="${preferences}" property="color" value="${param.color}" />

<c:out value="${preferences.color}" />

 


在浏览器地址栏输入如下地址访问例程8-7

http://localhost:8080/JSTL/c_set2.jsp?color=green

例程8-7的运行结果如图8.5所示。

8.5

8.3.3  <c:remove>标签

<c:remove>标签用于删除各种Web域中的属性,其语法格式如下:

<c:remove var="varName"   

    [scope="{page|request|session|application}"] />

var属性用于指定要删除的属性的名称,scope属性用于指定要删除的属性所属的Web域,它们的值都不能接受动态值。如果没有指定scope属性,<c:remove>标签就调用PageContext.removeAttribute(varName)方法,否则就调用PageContext.removeAttribute(varName, scope) 方法。<c:remove><c:set>标签第一种语法格式的value属性值为null时的作用相同。

例程8-8是使用<c:remove>标签的一个演示例子程序。

例程8-8 c_remove.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<c:set value="org.it315" var="company" scope="request" />

<c:set var="passWord" scope="session">

a123456a

</c:set>

在没有使用 &lt;c:remove&gt; 标签之前,变量的值为:<br />

company:<c:out value="${company}" /><br />

passWord:<c:out value="${passWord}" /><br />

<c:remove var="company" scope="request" />

<!--c:set var="company" scope="request" 此行与黑体字的一行作用是一样的/-->

<c:remove var="passWord" scope="session" /><hr />

在使用 &lt;c:remove&gt; 标签之后,变量的值为:<br />

company:<c:out value="${company}" /><br />

passWord:<c:out value="${passWord}" />

 


例程8-8运行结果如图8.6示。

8.6

8.3.4  <c:catch>标签

<c:catch>标签用于捕获嵌套在标签体中的内容抛出的异常,其语法格式如下:

<c:catch [var="varName"]>

nested actions

</c:catch>

var属性用于标识<c:catch>标签捕获的异常对象,其值是一个静态的字符串,不支持动态属性值。<c:catch>标签将捕获的异常对象以var指定的名称保存到page这个Web域中,如果没有指定var属性,则<c:catch>标签仅捕获异常,不在page域保存异常对象。如果<c:catch>标签体中的内容没有抛出异常,<c:catch>标签将从page域中删除var属性指定的属性。

<c:catch>标签可以捕获任何标签抛出的异常,并且可以同时处理多个标签抛出的异常,这样,可以对JSP页面的异常进行统一处理,显示给用户一个更友好的页面。JSP处理异常的通用机制是出现重要异常后跳转到错误处理页面,建议尽量不要用<c:catch>标签来代替JSP的错误处理机制,只对一些次要异常才使用<c:catch>标签进行捕获处理。

例程8-9是使用<c:catch>标签进行异常捕获处理的一个演示例子程序。

8-9  c_catch.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<c:catch var="myex">

<%

int i = 0;

int j = 10;

out.println(j + "/" + i + "=" + j/i);

%>

</c:catch>

异常:<c:out value="${myex}" /><br />

异常 myex.getMessage<c:out value="${myex.message}" /><br />

异常 myex.getCause<c:out value="${myex.cause}" /><br />

异常 myex.getStackTrace<c:out value="${myex.stackTrace}" />

 


在例程8-9<c:catch>标签内嵌套的脚本元素抛出了异常,<c:catch var="myex">将捕获到这个异常,调用<c:out value="${myex.message}" />,相当于调用<%=myex.getMessage()%>例程8-9运行结果如图8.7所示

8.7

8.3.5  <c:if>标签

JSP页面的显示逻辑中也经常需要进行条件判断,<c:if>标签可以构造简单的“if-then”结构的条件表达式,如果条件表达式的结果为真就执行标签体部分的内容。<c:if>标签有两种语法格式:

语法1,没有标签体的情况:

<c:if test="testCondition" var="varName"

        [scope="{page|request|session|application}"] />

语法2,有标签体的情况,在标签体中指定要执行的内容:

<c:if test="testCondition" [var="varName"]

        [scope="{page|request|session|application}"]>

    body content

</c:if>

<c:if>标签的属性说明如表8.5所示。

表8.5   <c:if>标签的属性

属性名

是否支持EL

属性类型

test

true

boolean

决定是否处理标签体中的内容的条件表达式

var

false

String

用于指定将test属性的执行结果保存到某个Web域中的某个属性的名称

scope

false

String

指定将test属性的执行结果保存到哪个Web域中

 

对于语法2,如果指定了<c:if>标签的scope属性,则必须指定var属性。

例程8-10是使用<c:if>标签的一个演示例子程序。

例程8-10  c_if.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<jsp:useBean id="user" class="org.it315.UserBean" />

<c:set value="${param.count}" target="${user}" property="visitCount" />

<c:if test="${user.visitCount == 1}">

这是您第一次访问本网站,欢迎您!

</c:if>

 


在浏览器地址栏输入如下地址访问例程8-10

http://localhost:8080/JSTL/c_if.jsp?count=1

例程8-10运行结果如8.8示。

8.8

8.3.6  <c:choose>标签

<c:choose>标签用于指定多个条件选择的组合边界,它必须与<c:when>和<c:otherwise>标签一起使用。使用<c:choose>,<c:when>和<c:otherwise>三个标签,可以构造类似“if-else if-else”的复杂条件判断结构。

<c:choose>标签没有属性,在它的标签体内只能嵌套一个或多个<c:when>标签和0个或一个<c:otherwise>标签,并且同一个<c:choose>标签中的所有<c:when>子标签必须出现在<c:otherwise>子标签之前。如果<c:choose>标签内嵌套一个<c:when>标签和<c:otherwise>标签,就相当于“if-else”的条件判断结构;如果<c:choose>标签内嵌套多个<c:when>标签和一个<c:otherwise>标签,就相当于“if-else if-else”标签。

<c:when>标签只有一个test属性,该属性的值为布尔类型。test属性支持动态值,其值可以是一个条件表达式,如果条件表达式的值为true,就执行这个<c:when>标签体的内容。<c:when>标签体的内容可以是任意的JSP代码。<c:otherwise>标签没有属性,它必须作为<c:choose>标签的最后分支出现。

当JSP页面中使用<c:choose>标签时,嵌套在<c:choose>标签内的test条件成立的第一个<c:when>标签的标签体内容将被执行和输出。当且仅当所有的<c:when>标签的test条件都不成立时,才执行和输出<c:otherwise>标签的标签体内容。如果所有的<c:when>标签的test条件都不成立,并且<c:choose>标签内没有嵌套<c:otherwise>标签,则不执行任何操作。

例程8-11是使用<c:choose>、<c:when>、<c:otherwise>标签的一个演示例子程序。

8-11 c_choose.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<c:set value="${param.count}" var="count" />

<c:choose>

<c:when test="${count == 0}">

    对不起,没有符合您要求的记录。

</c:when>

<c:otherwise>

    符合您要求的记录共有${count}.

</c:otherwise>

</c:choose>

 


在浏览器地址栏输入如下地址访问例程8-11

http://localhost:8080/JSTL/c_choose.jsp?count=0

例程8-11的运行结果如图8.9所示。如果将参数count的值修改为10,则运行结果如图8.10所示。

 

 

8.9

8.10

 

例程8-12是一个综合使用<c:if>标签和<c:choose>等标签的例子程序,在这个例子程序中,首先使用<c:if>标签判断表单提交的方式是否是POST,如果是,就再使用<c:choose>等标签根据表单提交的内容进行不同的处理。

程8-12  c_customLogic.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<c:if test="${pageContext.request.method=='POST'}">

       <c:choose>

              <c:when test="${param.favor == 'computer'}">

                     Your favourite course is <b>computer</b>.

              </c:when>

              <c:otherwise>

                     Your favourite course is <i>other</i>.

              </c:otherwise>

       </c:choose>

</c:if>

<form method="POST">What is your favourite course?<br/>

<input type="text" name="favor" />

<input type="submit" value="submit" />

</form>

 


在浏览器地址栏中直接访问c_customLogic.jsp运行结果如8.11示,在文本框中输入“computer”,单击其中的submit按钮后的运行结果如图8.12示。

8.11

8.12

8.3.7  <c:forEach>标签

JSP页面的显示逻辑中也经常需要对集合对象进行循环迭代操作,<c:forEach>标签用于对一个集合对象中的元素进行循环迭代操作,或者按指定的次数重复迭代执行标签体中的内容。<c:forEach>标签有两种语法格式:

语法1,在集合对象中迭代:

<c:forEach [var="varName"]

            items="collection"

            [varStatus="varStatusName"]

            [begin="begin"] [end="end"] [step="step"]>

    body content

</c:forEach>

语法2,迭代固定的次数:

<c:forEach [var="varName"]

            [varStatus="varStatusName"]

            begin="begin" end="end" [step="step"]>

    body content

</c:forEach>

<c:forEach>标签的属性说明如表8.6所示。

表8.6  <c:forEach>标签的属性

属性名

是否支持EL

属性类型

属 性 描 述

var

false

String

指定将当前迭代到的元素保存到page这个Web域中的属性名称

items

true

任何支持的类型

将要迭代的集合对象

varStatus

false

String

指定将代表当前迭代状态信息的对象保存到page这个Web域中的属性名称

begin

true

int

如果指定items属性,就从集合中的第begin个元素开始进行迭代,begin的索引值从0开始编号;如果没有指定items属性,就从begin指定的值开始迭代,直到end值时结束迭代

end

true

int

参看begin属性的描述

step

true

int

指定迭代的步长,即迭代因子的迭代增量

 

在使用<c:forEach>标签时,需要注意如下几点说明:

l  如果指定begin属性,其值必须大于或等于零;

l  如果指定步长(step属性),其值必须大于或等于1;

l  如果items属性的值为null,则要处理的集合对象为空,这时不执行迭代操作;

l  如果指定的begin属性的值大于或等于集合对象的长度,不执行迭代操作;

l  如果指定的end属性的值小于begin属性的值,不执行迭代操作;

 

<c:forEach>标签的items属性的值支持下面的数据类型:

l  任意类型的数组

l  java.util.Collection

l  java.util.Iterator

l  java.util.Enumeration

l  java.util.Map

l  String

items属性还支持与数据库有关的数据类型java.sql.ResultSet(包括javax.sql.RowSet),这些数据类型将在8.5 节的数据库标签中进行介绍。对字符串的迭代操作通常使用<c:forTokens>标签或JSTL函数,例如fn:split和fn:jion,JSTL函数将在8.7节进行介绍。

 

1.迭代Collection类型的集合对象

例程8-13是使用<c:forEach>标签迭代Collection类型的集合对象的一个应用举例。

例程8-13  c_forEach_collection.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<%@ page import="java.util.*,org.it315.UserBean" %>

<%

       Collection users = new ArrayList();

       for(int i=0; i<5; i++)

       {

              UserBean user = new UserBean();

              user.setUserName("user" + i);

              user.setPassword("guess" + i);

              users.add(user);

       }

       session.setAttribute("users", users);

%>

       <div style="text-align:center">User List

       <table border="1">

              <tr><td>用户名</td><td>密码</td></tr>

              <c:forEach var="user" items="${users}">

                     <tr>

                            <td>${user.userName}</td><td>${user.password}</td>

                     </tr>

              </c:forEach>

       </table></div>

 


例程8-13的运行结果如图8.13所示。

图8.13

2.迭代Map对象

使用<c:forEach>标签迭代Map类型的集合对象时,迭代出的每个元素的类型为Map.Entry,Map.Entry代表Map集合中的一个条目项,其中的getKey()方法可获得条目项的关键字,getValue()方法可获得条目项的值。

EL中的requestScope隐含对象代表request作用域中的所有属性的Map对象,所以我们可以使用<c:forEach>标签迭代输出EL中的requestScope隐含对象中的所有元素,如例程8-14所示。

例程8-14 c_forEach_map.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

       <%

              request.setAttribute("attr1","value1");

              request.setAttribute("attr2","value2");

       %>

       <div style="text-align:center">Properties(Map)

       <table border="1">

              <tr><td>Map的关键字</td><td>Map的对应关键字的值</td></tr>

              <c:forEach var="entry" items="${requestScope}">

                     <tr><td>${entry.key}</td><td>${entry.value}</td></tr>

              </c:forEach>

       </table></div>

 


例程8-14运行结果如图8.14所示。

图8.14

3.迭代指定的次数

<c:forEach>标签可以按指定的次数重复迭代执行标签体中的内容,使用这种方式迭代时,可以指定迭代的步长。例程8-15中分别演示了指定迭代步长和没有指定迭代步长的情况。

例程8-15 c_forEach_count.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

1116迭代,指定迭代步长为2

<c:forEach var="i" begin="11" end="16" step="2">

       ${i}

</c:forEach><br /><hr />

05迭代,没有指定迭代步长:

<c:forEach var="i" begin="0" end="5">

       ${i}

</c:forEach>

 


例程8-15的运行结果如图8.15示。

图8.15

4.指定迭代集合对象的范围和步长

<c:forEach>标签迭代集合类对象时,也可以指定迭代的范围和步长,如例程8-16所示。

例程8-16 c_forEach_col.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<%@ page import="java.util.*,org.it315.UserBean" %>

<%

    Collection users = new ArrayList();

    for(int i=0; i<6; i++)

    {

        UserBean user = new UserBean();

        user.setUserName("user" + i);

        user.setPassword("guest" + i);

        users.add(user);

    }

    session.setAttribute("users", users);

%>

<div style="text-align:center">User List(指定迭代范围和步长)

<table border="1">

    <tr><td>用户名</td><td>密码</td></tr>

    <c:forEach var="user" items="${users}" end="5" step="2">

        <tr>

            <td>${user.userName}</td><td>${user.password}</td>

        </tr>

    </c:forEach>

</table></div>

 


例程8-16的运行结果如图8.16所示。

图8.16

5.获取迭代的状态信息

不管是迭代集合对象,还是迭代指定的次数,在迭代时都可以获得当前的迭代状态信息。<c:forEach>标签可以将代表当前迭代状态信息的对象保存到page中,varStatus属性指定了这个对象保存在page域中的属性名称。代表当前迭代状态信息的对象的类型为javax.servlet.jsp.jstl.core.LoopTagStatus,从JSTL规范中可以查看到这个类的详细信息,其中定义了如下一些方法:

l  public java.lang.Integer getBegin()
返回为标签设置的begin属性的值,如果没有设置begin属性则返回null

l  public int getCount()
返回当前已循环迭代的次数

l  public java.lang.Object getCurrent()
返回
当前迭代到的元素对象

l  public java.lang.Integer getEnd()
返回为标签设置的end属性的值,如果没有设置end属性则返回null

l  public int getIndex()
返回
当前迭代的索引号

l  public java.lang.Integer getStep()
返回为标签设置的step属性的值,如果没有设置step属性则返回null

l  public boolean isFirst()
返回
当前是否是第一次迭代操作

l  public boolean isLast()
返回
当前是否是最后一次迭代操作

 

例程8-17是一个获取迭代状态信息的例子程序。

例程8-17 c_forEach_col2.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<%@ page import="java.util.*,org.it315.UserBean" %>

<%

    Collection users = new ArrayList();

    for(int i=0; i<6; i++)

    {

        UserBean user = new UserBean();

        user.setUserName("user" + i);

        user.setPassword("guest" + i);

        users.add(user);

    }

    session.setAttribute("users", users);

%>

<div style="text-align:center">User List

<table border="1">

    <tr><td>用户名</td><td>密码</td><td>index</td>

    <td>count</td><td>first?</td><td>last?</td></tr>

    <c:forEach var="user" items="${users}" varStatus="sta" begin="1" step="2">

        <tr>

            <td>${user.userName}</td><td>${user.password}</td>

            <td>${sta.index}</td><td>${sta.count}</td>

            <td>${sta.first}</td><td>${sta.last}</td>

        </tr>

    </c:forEach>

</table></div><hr>

 

<div style="text-align:center">迭代固定的次数

<table border="1">

    <tr><td>数值</td><td>index</td><td>count</td>

    <td>first?</td><td>last?</td></tr>

    <c:forEach var="i" varStatus="sta1" begin="101" end="103">

        <tr>

            <td>${i}</td><td>${sta1.index}</td><td>${sta1.count}</td>

            <td>${sta1.first}</td><td>${sta1.last}</td>

        </tr>

    </c:forEach>

</table></div>

 


例程8-17的运行结果如图8-17所示。

图8.17

6.与条件标签结合使用

迭代标签可以与条件标签结合使用,对数据进行有条件的迭代,应用举例如例程8-18所示。

例程8-18 c_forEach_com.jsp

 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page contentType="text/html;charset=gb2312" %>

<div style="text-align:center">

<table border="1"><tr><td>number</td><td>count</td><td>even|odd</td></tr>

<c:forEach var="i" begin="11" end="13" varStatus="status">

       <tr><td>${i}</td><td>${status.count}</td><td>

       <c:choose>

              <c:when test="${status.count % 2 == 0}">

                     偶数行

              </c:when>

              <c:otherwise>

                     奇数行

              </c:otherwise>

       </c:choose></td></tr>

</c:forEach>

<table></div>

 


例程8-18的运行结果如图8.18所示。

图8.18

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值