jstl

JSTL详解(一)
概述
在 JSP 页面中,使用标签库代替传统的 Java 片段语言来实现页面的显示逻辑已经不是新技术了,然而,由自定义标签很容易造成重复定义和非标准的实现。鉴于此,出现了 JSTL ( JSP Standard Tag Library )。
JSTL 的发布包有两个版本: Standard-1.0 Taglib 、 Standard-1.1 Taglib ,它们在使用时是不同的。
         Standard-1.0 Taglib ( JSTL1.0 )支持 Servlet2.3 和 JSP1.2 规范, Web 应用服务器 Tomcat4 支持这些规范,而它的发布也在 Tomcat 4.1.24 测试通过了。
         Standard-1.1 Taglib ( JSTL1.1 )支持 Servlet2.4 和 JSP2.0 规范, Web 应用服务器 Tomcat5 支持这些规范,它的发布在 Tomcat 5.0.3 测试通过了。
介绍中,将以由 Sun 发布的 Standard-1.1 Taglib 标签库为主,而 apache jakarta 组织发布的开源标签库,可以从 http://jakarta.apache.org/taglibs/ 找到所需要的帮助。

Sun 发布的标准 JSTL1.1 标签库有以下几个标签:
         核心标签库:包含 Web 应用的常见工作,比如:循环、表达式赋值、基本输入输出等。
         国际化标签库:用来格式化显示数据的工作,比如:对不同区域的日期格式化等。
         数据库标签库:可以做访问数据库的工作。
         XML 标签库:用来访问 XML 文件的工作,这是 JSTL 标签库的一个特点。
         函数标签库:用来读取已经定义的某个函数。
此外, JSTL 还提供了 EL 表达式语言( Expression Language )来进行辅助的工作。

JSTL 标签 库由标签库和 EL 表达式语言两个部分组成。 EL 在 JSTL 1.0 规范中被引入,当时用来作为 Java 表达式来工作,而该表达式必须配合 JSTL 的标签库才能得到需要的结果。

说明:在 JSTL 1.1 规范中, JSP2.0 容器已经能够独立的理解任何 EL 表达式。 EL 可以独立出现在 JSP 页面的任何角落。

9.2.1  JSTL EL 表达式语言简介
EL 是从 JavaScript 脚本语言得到启发的一种表达式语言,它借鉴了 JavaScript 多类型转换无关性的特点。在使用 EL 从 scope 中得到参数时可以自动转换类型,因此对于类型的限制更加宽松。
Web 服务器对于 request 请求参数通常会以 String 类型来发送,在得到时使用的 Java 语言脚本就应该是 request.getParameter(“XXX”) ,这样的话,对于实际应用还必须进行强制类型转换。而 EL 就将用户从这种类型转换的繁琐工作脱离出来,允许用户直接使用 EL 表达式取得的值,而不用关心它是什么类型。
下面的示例就是一个 EL 表达式
例 9.1 :简单 EL 表达式
<%@ page contentType="text/html; charset=UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

  <body>

    ${sampleValue + 1} <br>

  </body>

</html>

这个示例将在 JSP 页面显示为“ 1 ”, EL 表达式必须以“ ${XXX} ”来表示,其中“ XXX ”部分就是具体表达式内容,“ ${} ”将这个表达式内容包含在其中作为 EL 表达式的定义。本示例可以在满足 JSP2.0 规范的任何 Web 应用服务器中使用。

9.2.2  EL 表达式的默认变量
一个 EL 表达式包含变量和操作符两个内容。任何存在于 JSP 作用范围的 JavaBean 都可以被转化成 EL 表达式来使用,它所包含的默认变量如下:
1 .默认变量 pageScope 、 requestScope 、 sessionScope 、 applicationScope

这 4 个默认变量包含 Scope 作用范围的参数集合,相当于被保存在 java.util.Map 中的某个参数。

下面看简单的示例 9.2 :
例 9.2 :使用 sessionScope 变量的 EL 表达式

<%request.getSession().setAttribute("sampleValue", new Integer(10));%>

${sessionScope.sampleValue}

取得保存在 Session 中参数的 sessionScope 变量的 EL 表达式,“ . ”是 property 访问操作符,在这里表示从 Session 中取得“键”为“ sampleValue ”的参数,并显示出来。显示结果为“ 10 ”。

2 .默认变量 param 、 paramValues

这两个默认变量包含请求参数的集合, param 表明请求包含的参数为单一控件, paramValues 表明请求包含的参数为控件数组。下面看一个简单示例 9.3 :
例 9.3 :提交请求的页面和接受的页面
<%@ page contentType="text/html; charset=UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

  <body>

       <form action="SampleJsp.jsp">

    <input type="text" name="sampleValue" value="10">

    <input type="text" name="sampleValue" value="11">

    <input type="text" name="sampleValue" value="12">

    <input type="text" name="sampleSingleValue" value="SingleValue">

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

    </form>

  </body>

</html>

在这个页面中定义了两组控件,控件名为“ sampleValue ”的是一套控件数组,控件名为“ sampleSingleValue ”的是单一控件,通过递交将请求参数传送到 SampleJsp.jsp 。
<%@ page contentType="text/html; charset=UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

  <body>

    ${paramValues.sampleValue[2]} <br>

    ${param.sampleSingleValue} <br>

  </body>

</html>

这是请求转发到的页面,通过 EL 表达式的 paramValues 变量得到控件数组中最后一个控件的递交参数,通过 EL 表达式的 param 变量得到单一控件的递交参数。控件数组参数的 EL 表达式使用“ [] ”来指定数组下标。本示例将显示控件数组中最后一个控件的值“ 12 ”和单一控件的值“ SingleValue ”。
3 .默认变量 header 、 headerValues

这两个默认变量包含请求参数头部信息的集合, header 变量表示单一头部信息, headerValues 则表示数组型的头部信息。
4 .默认变量 cookie

包含所有请求的 cookie 集合,集合中的每个对象对应 javax.servlet.http.Cookie 。
5 .默认变量 initParam

包含所有应用程序初始化参数的集合。
6 .默认变量 pageContext

等价于 page 环境类 javax.servlet.jsp.PageContext 的实例,用来提供访问不同的请求参数。
11 个默认变量几乎包含了 Web 应用的所有基本操作,若一个表达式不使用这些变量而直接使用参数名,那么就采用就近原则。该表达式将使用最近取得的参数值。

JSTL详解(二)(转载)

9.2.3  EL 表达式的操作符
EL 表达式中还有许多操作符可以帮助完成各种所需的操作,之前的示例中“ . ”、“ [] ”就是其中的两个,
下面将用表 9.1 来展示所有操作符及它们各自的功能。


表 9.1  EL 表达式的操作符
操作符
 功能和作用
 
.
 访问一个 bean 属性或者 Map entry
 
[]
 访问一个数组或者链表元素
 
()
 对子表达式分组,用来改变赋值顺序
 
? :
 条件语句,比如:条件 ?ifTrue:ifFalse

如果条件为真,表达式值为前者,反之为后者
 
+
 数**算符,加操作
 
-
 数**算符,减操作或者对一个值取反
 
*
 数**算符,乘操作
 
/ 或 div
 数**算符,除操作
 
% 或 mod
 数**算符,模操作 ( 取余 )
 
== 或 eq
 逻辑运算符,判断符号左右两端是否相等,如果相等返回 true ,否则返回 false
 
!= 或 ne
 逻辑运算符,判断符号左右两端是否不相等,如果不相等返回 true ,否则返回 false
 
< 或 lt
 逻辑运算符,判断符号左边是否小于右边,如果小于返回 true ,否则返回 false
 
> 或 gt
 逻辑运算符,判断符号左边是否大于右边,如果大于返回 true ,否则返回 false
 
<= 或 le
 逻辑运算符,判断符号左边是否小于或者等于右边,如果小于或者等于返回 true ,否则返回 false
 
>= 或 ge
 逻辑运算符,判断符号左边是否大于或者等于右边,如果大于或者等于返回 true ,否则返回 false
 
&& 或 and
 逻辑运算符,与操作赋。如果左右两边同为 true 返回 true ,否则返回 false
 
|| 或 or
 逻辑运算符,或操作赋。如果左右两边有任何一边为 true 返回 true ,否则返回 false
 
! 或 not
 逻辑运算符,非操作赋。如果对 true 取运算返回 false ,否则返回 true
 
empty
 用来对一个空变量值进行判断 : null 、一个空 String 、空数组、 空 Map 、没有条目的 Collection 集合
 
func(args)
 调用方法 , func 是方法名, args 是参数,可以没有,或者有一个、多个参数 . 参数间用逗号隔开 

这些操作符都是极其有用的,下面通过几个示例来演示它们的使用方法:
例 9.4 :几组操作符的示例
${pageScope.sampleValue + 12} <br>            // 显示 12

${(pageScope.sampleValue + 12)/3} <br>      // 显示 4.0

${(pageScope.sampleValue + 12) /3==4} <br>         // 显示 true

${(pageScope.sampleValue + 12) /3>=5} <br>         // 显示 false

<input type="text" name="sample1" value="${pageScope.sampleValue + 10}"> // 显示值为 10 的 Text 控件
可以看到,对于这些示例,程序设计者完全无需管理它们的类型转换,在表达式内部都已经处理了。有了 EL 表达式,在 JSP 页面的编程变得更灵活,也更容易。

9.2.3  JSTL 标签库介绍
在 JSTL1.1 中有以下这些标签库是被支持的: Core 标签库、 XML processing 标签库、 I18N formatting 标签库、 Database access 标签库、 Functions 标签库。对应的标识符见表 9.2 所示:
表 9.2 标签库的标识符
标签库        URI                        前缀
 Core        http://java.sun.com/jsp/jstl/core        c
 XML processing http://java.sun.com/jsp/jstl/xml        x
 I18N formatting http://java.sun.com/jsp/jstl/fmt        fmt
 Database access http://java.sun.com/jsp/jstl/sql        sql
 Functions    http://java.sun.com/jsp/jstl/functions        fn
 
下面看例 9.5 ,简单使用标签库的示例。
例 9.5 :简单 JSTL 标签库示例
<%@ page contentType="text/html; charset=UTF-8"%>

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

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>

  <body>

    <c:forEach var="i" begin="1" end="10" step="1">

      ${i}

     


    </c:forEach>

  </body>

</html>

在该示例的 JSP 页面中声明了将使用 Core 标签库,它的 URI 为“ http://java.sun.com/jsp/jstl/core ”,前缀为“ c ”。之后,页面中 <c:forEach> 标签就是使用了 JSTL 的标签进行了工作。

                9.3  JSTL Core 标签库
Core 标签库,又被称为核心标签库,该标签库的工作是对于 JSP 页面一般处理的封装。在该标签库中的标签一共有 14 个,被分为了四类,分别是:
         多用途核心标签: <c:out> 、 <c:set> 、 <c:remove> 、 <c:catch> 。
         条件控制标签: <c:if> 、 <c:choose> 、 <c:when> 、 <c:otherwise> 。
         循环控制标签: <c:forEach> 、 <c:forTokens> 。
         URL 相关标签: <c:import> 、 <c:url> 、 <c:redirect> 、 <c:param> 。
以下是各个标签的用途和属性以及简单示例。
9.3.1  用于显示的 <c:out> 标签
<c:out> 标签是一个最常用的标签,用于在 JSP 中显示数据。它的属性和描述如表
9.3 所示:
表 9.3  
<c:out> 标签属性和说明

value
输出到页面的数据,可以是 EL 表达式或常量(必须)
 
default
 当 value 为 null 时显示的数据(可选)
 
escapeXml
 当设置为 true 时会主动更换特殊字符,比如“ &lt;,&gt;,&amp; ”(可选,默认为 true )
 

在 JSTL1.0 的时候,在页面显示数据必须使用 <c:out> 来进行。然而,在 JSTL1.1 中,由于 JSP2.0 规范已经默认支持了 EL 表达式 ,因此可以直接在 JSP 页面使用表达式。下面看一个示例。
<c:out value="${sessionScope.anyValue}" default="no value" escapeXml="false"/>

该示例将从 Session 查找名为“ anyValue ”的参数,并显示在页面,若没有找到则显示“ no value ”。

JSTL详解(三) 
 
 
9.3.2  用于赋值的 <c:set> 标签 
 

<c:set> 标签用于为变量或 JavaBean 中的变量属性赋值的工作。它的属性和描述如:

<c:set> 标签属性和说明
var 被赋值的变量名(可选)
value 值的信息,可以是 EL 表达式或常量
scope 变量的作用范围,若没有指定,默认为 page (可选)
target 被赋值的 JavaBean 实例的名称,若存在该属性则必须存在 property 属性(可选)
property JavaBean 实例的变量属性名称(可选)
 
当不存在 value 的属性时,将以包含在标签内的实体数据作为赋值的内容
下面看一个示例:

<c:set value="this is andy" var="oneString"/>

${oneString} <br>

该示例将为名为“ oneString ”的变量赋值为“ this is andy ”,其作用范围为 page 。

9.3.3  用于删除的 <c:remove> 标签
<c:remove> 标签用于删除存在于 scope 中的变量。
<c:remove> 标签属性和说明
 var 需要被删除的变量名
 scope 变量的作用范围,若没有指定,默认为全部查找(可选)
 下面看一个示例:
<c:remove var="sampleValue" scope="session"/>

${sessionScope.sampleValue} <br>

该示例将存在于 Session 中名为“ sampleValue ”的变量删除。下一句 EL 表达式显示该变量时,该变量已经不存在了。

9.3.4  用于异常捕获的 <c:catch> 标签
<c:catch> 标签允许在 JSP 页面中捕捉异常。
它包含一个 var 属性,是一个描述异常的变量,改变量可选。
若没有 var 属性的定义,那么仅仅捕捉异常而不做任何事情;
若定义了 var 属性,则可以利用 var 所定义的异常变量进行判断转发到其他页面或提示报错信息。看一个示例。

<c:catch var="err">

         ${param.sampleSingleValue== 3}

</c:catch>

${err}

当“ ${param.sampleSingleValue== 3} ”表达式有异常时,
可以从 var 属性“ err ”得到异常的内容,通常判断“ err ”是否为 null 来决定错误信息的提示。

ex2:

<c:set value="this is andy" var="oneString" scope="session"/>
<c:catch var="err">

  ${oneString+333} <br>

</c:catch>
${err}

9.3.5  用于判断的 <c:if> 标签
<c:if> 标签用于简单的条件语句。它的属性和描述如表 9.6 所示:

表 9.6   <c:if> 标签属性和说明

属性
 描述
 
test
 需要判断的条件
 
var
 保存判断结果 true 或 false 的变量名,该变量可供之后的工作使用(可选)
 
scope
 变量的作用范围,若没有指定,默认为保存于 page 范围中的变量(可选)
 

下面看一个示例:

<c:if test="${paramValues.sampleValue[2] == 12}" var="visits">

      It is 12

</c:if><br>

${visits} <br>

该示例将判断 request 请求提交的传入控件数组参数中,下标为“ 2 ”的控件内容是否为“ 12 ”,若为 12 则显示“ It is 12 ”。判断结果被保存在 page 范围中的“ visits ”变量中。  

9.3.6  用于复杂判断的 <c:choose> 、 <c:when> 、 <c:otherwise> 标签
这三个标签用于实现复杂条件判断语句,类似“ if,elseif ”的条件语句。

q         <c:choose> 标签没有属性,可以被认为是父标签, <c:when> 、 <c:otherwise> 将作为其子标签来使用。

q         <c:when> 标签等价于“ if ”语句,它包含一个 test 属性,该属性表示需要判断的条件。

q         <c:otherwise> 标签没有属性,它等价于“ else ”语句。

下面看一个复杂条件语句的示例。

<c:choose>

         <c:when test="${paramValues.sampleValue[2] == 11}">

                   not 12 not 13,it is 11

         </c:when>

         <c:when test="${paramValues.sampleValue[2] == 12}">

                   not 11 not 13,it is 12

         </c:when>

         <c:when test="${paramValues.sampleValue[2] == 13}">

                   not 11 not 12,it is 13

         </c:when>

         <c:otherwise>

                   not 11 、 12 、 13

         </c:otherwise>

</c:choose>

该示例将判断 request 请求提交的传入控件数组参数中,下标为“ 2 ”控件内容是否为“ 11 ”或“ 12 ”或“ 13 ”,并根据判断结果显示各自的语句,若都不是则显示“ not 11 、 12 、 13 ”。

9.3.7  用于循环的 <c:forEach> 标签
<c:forEach> 为循环控制标签。它的属性和描述如表 9.7 所示:

表 9.7   <c:forEach> 标签属性和说明

属性
 描述
 
items
 进行循环的集合(可选)
 
begin
 开始条件(可选)
 
end
 结束条件(可选)
 
step
 循环的步长,默认为 1 (可选)
 
var
 做循环的对象变量名,若存在 items 属性,则表示循环集合中对象的变量名(可选)
 
varStatus
 显示循环状态的变量(可选)
 

下面看一个集合循环的示例。

<%ArrayList arrayList = new ArrayList();

                   arrayList.add("aa");

                   arrayList.add("bb");

                   arrayList.add("cc");

%>

<%request.getSession().setAttribute("arrayList", arrayList);%>

<c:forEach items="${sessionScope.arrayList}" var="arrayListI">

         ${arrayListI}

</c:forEach>

该示例将保存在 Session 中的名为“ arrayList ”的 ArrayList 类型集合参数中的对象依次读取出来, items 属性指向了 ArrayList 类型集合参数, var 属性定义了一个新的变量来接收集合中的对象。最后直接通过 EL 表达式显示在页面上。下面看一个简单循环的示例。

<c:forEach var="i" begin="1" end="10" step="1">

      ${i}


</c:forEach>

该示例从“ 1 ”循环到“ 10 ”,并将循环中变量“ i ”显示在页面上。

9.3.8  用于分隔字符的 <c:forTokens> 标签
<c:forTokens> 标签可以根据某个分隔符分隔指定字符串,相当于 java.util.StringTokenizer 类。它的属性和描述如表 9.8 所示:

表 9.8   <c:forTokens> 标签 属性和说明

属性
 描述
 
items
 进行分隔的 EL 表达式或常量
 
delims
 分隔符
 
begin
 开始条件(可选)
 
end
 结束条件(可选)
 
step
 循环的步长,默认为 1 (可选)
 
var
 做循环的对象变量名(可选)
 
varStatus
 显示循环状态的变量(可选)
 

下面看一个示例。

<c:forTokens items="aa,bb,cc,dd" begin="0" end="2" step="2" delims="," var="aValue">

         ${aValue}

</c:forTokens>

需要分隔的字符串为“ aa,bb,cc,dd ”,分隔符为“ , ”。 begin 属性 指定从第一个“ , ”开始分隔, end 属性指定分隔到第三个“ , ”,并将做循环的变量名指定为“ aValue ”。由于步长为“ 2 ”,使用 EL 表达式 ${aValue} 只能显示“ aa

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值