JSP标准标记库(Standard Tag Library,JSTL)是一组以标准化格式实现许多通用的Web站点功能的定制标记。
JSP 技术的优势之一在于其定制标记库工具。除了核心 JSP 标记,如 jsp:include 之外,定制标记库工具使您能够创建唯一的标记来描述以站点或应用程序为导向的操作。一旦您创建了定制标记库 ( 简称 taglib) ,当您扩展项目或转向另一个项目时您可以重复使用这些标记。您还可以将 taglib 传递给其它开发人员,从而他们可以在自己的网站上使用,或者在您 Web 应用程序的其它部分使用。
JSTL 的目标是为了简化 JSP 页面的设计。对于页面设计人员来说,使用脚本语言(默认值是 JAVA 语言)操作动态数据是比较困难的,而采用标签和表达式语言相对容易一些, JSTL 的使用为页面设计人员和程序开发人员的分工协作提供了便利。以下是JSP标准标记库JSTL的介绍。
一.配置 JSTL
包括两个 JAR 文件, jstl.jar 和 standard.jar 。是什么没有必要管,重在应用( 1+1 ? =2 ,我们没有必要深究,只需要知道这么用就行。)。
原文引入:
- <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
- <%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>
- <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
二.Core标签库
Core 标签库主要包括了一般用途的标签、条件标签、迭代标签和 URL 相关的标签。在 JSP 页面使用 Core 标签,要使用 taglig 指令,指定引用的标签库,如下:
- <%@ taglib rui=”http://java.sun.com/jsp/jstl/core” prefix=”c” %>
一般用途的标签有< c:out>、< c:set>、< c:remove>、< c:cath>
1.< c:out>
用于计算一个表达式并将结果输出。类似于 JSP 中 < %=%> 表达式,或者是 EL 中 $ ${el-expression} 。
2.< c:set>
用于设置范围变量的值或者 javabean 对象的属性。
看个实际例子:
- < c:set var=”username” value=”lisi” scope=”session”/>
这样就相当于设置了 session 。
3.< c:remove>
相对 < c:set> 其作用是移除范围变量。比如: < c:remove var=”nusername” scope=”session”/>
4.< c:catch>
用于捕获在其中嵌套的操作所抛出的异常对象,并将异常信息保存到变量中。
我们将有可能抛出异常的代码放置到开始标签 :< c:catch> 和结束标签 :< /c:catch> 之间。如果其中代码出现异常,异常对象将被捕获,保存在 var 声明的变量中,该变量总是有 page 范围。如果没有发生异常,而 var 所标识的范围变量将被移除。
如果没有指定 var 属性,异常只是简单的被捕获,异常信息并不会被保存。
- <c:catch var=”exception”>
- <%
- int i = 5;
- int j = 0;
- int k=i/j;
- %>
- <>c:catch>
- <c:out value=”${exception}” /><br>
- <c:out value=”${exception.massage}”/>
条件标签包括< c:if>< c:choose>< c:when>< c:otherwise>
1.< c:choose>
< c:choose> 和 < c:when> 、 < c:otherwise> 一起实现互斥条件执行,类似于 java 中的 if else.
< c:choose> 一般作为 < c:when> 、 < c:otherwise> 的父标签。
- <c:choose>
- <c:when test="${row.v_money<10000}">
- 初学下海
- <>c:when>
- <c:when test="${row.v_money>=10000&&row.v_money<20000}">
- 身手小试
- <>c:when>
- <c:otherwise>
- 商业能手
- <>c:otherwise>
- <>c:choose>
< c:choose> 操作的语法
- <c:choose>
- <c:whentestc:whentest="expression">
- bodycontent
- <>c:when>
- <c:whentestc:whentest="expression">
- bodycontent
- <>c:when>
- ...
- <c:otherwise>
- bodycontent
- <>c:otherwise>
- <>c:choose>
注意:每个要测试的条件都由相应的 < c:when> 标记来表示,至少要有一个 < c:when> 标记。只会处理第一个其 test 值为 true 的 < c:when> 标记体内的内容。如果没有一个 < c:when> 测试返回 true ,那么会处理 < c:otherwise> 标记的主体内容。注:尽管如此, < c:otherwise> 标记却是可选的; < c:choose > 标记至多可有一个嵌套的 < c:otherwise> 标记
2.< c:if>
用于实现 java 中的 if 语句功能。
- <c:if test=”${user.visitCount==1}”>
- This is your first visit .
- <>c:if>
若为true,会打印中间部分。也可以声明var,方便下一步判断。
迭代标签迭代标签有< c:forEach>和< /c:forEach>
- //遍历记录集
- <c:forEachitemsc:forEachitems="${finalResult.rows}"var="row">
- <trclasstrclass="<%=tdClass[(rank+1)%2]%>">
- <tdaligntdalign="center"><span><%=rank%><>span><>td>
- <tdaligntdalign="center"><span><c:outvaluec:outvalue="${row.player_name}"/><>span><>td>
- <tdaligntdalign="center"><span>¥<c:outvaluec:outvalue="${row.money}"/><>span><>td>
- <>tr>
- <%rank++;%>
- <>c:forEach>
- 也可以设定固定次数。
- <c:forEachvarc:forEachvar=”i”begin=”100“end=“110”>
- ${i}
- <>c:forEach>
- 如果再加个step=“2”那么每次增长为2。
三.sql标签
- 设置数据源:
- <sql:setDataSourcedataSourcesql:setDataSourcedataSource="proxool.breadTycoon"/>
- //将数据库某查询的结果声明为一个变量
- <sql:queryvarsql:queryvar="finalResult">
- selectplayer_name,moneyfromtb_playerorderbymoneyDESCLIMIT10
- <>sql:query>
- 然后可以:
- <c:forEachitemsc:forEachitems="${finalResult.rows}"var="row"varStatus="s">
- advCosts[${s.index}]=${row.adv_cost};
- <>c:forEach>
- 数据更新标签:
- <sql:update>
- callproc_set_role_salespro(?,?,?,?,?);
- <sql:paramvaluesql:paramvalue="30"/>
- <sql:paramvaluesql:paramvalue="39"/>
- <sql:paramvaluesql:paramvalue="<%=spID%>"/>
- <sql:paramvaluesql:paramvalue="<%=productID%>"/>
- <sql:paramvaluesql:paramvalue="1"/>
- <>sql:update>
- <sql:queryvarsql:queryvar="queryAllChannelCount">
- SELECTCOUNT(*)astotalFROMtb_channelWHEREgame_id=?ANDbegin_round
<func_cur_round(?)ANDplayer_id=?ANDchannel_flag=0- <sql:paramvaluesql:paramvalue="${gameID}"/>
- <sql:paramvaluesql:paramvalue="${gameID}"/>
- <sql:paramvaluesql:paramvalue="${playerID}"/>
- <>sql:query>
- <c:forEachitemsc:forEachitems="${queryAllChannelCount.rowsByIndex}"var="channelCN">
- <c:setvaluec:setvalue="${channelCN[0]}"var="channelTotal"/>
- <>c:forEach>
调用存储过程更新数据库:
- <c:if test="${param.changsubmit!=null}" >
- <c:forEach items="${paramValues.pro_id}" var="getpro_id" varStatus="getparamsta">
- <sql:update>
- call proc_set_role_product(?,?,?,?,?,?,?,?);
- <sql:param value="${gameID}"/>
- <sql:param value="${playerID}"/>
- <sql:param value="${getpro_id}"/>
- <sql:param value="${getpro_id}"/>
- <sql:param value="${paramValues.pro_sort[getparamsta.index]}"/>
- <sql:param value="${paramValues.price[getparamsta.index]}"/>
- <sql:param value="${paramValues.output[getparamsta.index]}"/>
- <sql:param value="0"/>
- </sql:update>
- </c:forEach>
- </c:if>
四.格式化标签
- <fmt:formatNumbervaluefmt:formatNumbervalue=”12.3”pattern=”.000”/>
- 将输出12.300.应用样式”.000”,将使格式化后的小数部分有3位。不足3位将以0补齐。
- <fmt:formatDatevaluefmt:formatDatevalue=”<%=newjava.util.Date()%>”type=”date”/>
- 格式化的结果是:2007-5-27.
- <fmt:formatDatevaluefmt:formatDatevalue=”<%=newjava.util.Date()%>”type=”time”/>
- 格式化的结果是:9:25:11
- <fmt:formatDatevaluefmt:formatDatevalue=”<%=newjava.util.Date()%>”type=”both”/>
- 格式化的结果是:2007-5-279:25:11