全面介紹JSP標(biāo)準(zhǔn)標(biāo)記庫JSTL
JSP標(biāo)準(zhǔn)標(biāo)記庫(Standard Tag Library,JSTL)是一組以標(biāo)準(zhǔn)化格式實(shí)現(xiàn)許多通用的Web站點(diǎn)功能的定制標(biāo)記。
JSP 技術(shù)的優(yōu)勢之一在于其定制標(biāo)記庫工具。除了核心 JSP 標(biāo)記,如 jsp:include 之外,定制標(biāo)記庫工具使您能夠創(chuàng)建唯一的標(biāo)記來描述以站點(diǎn)或應(yīng)用程序?yàn)閷?dǎo)向的操作。一旦您創(chuàng)建了定制標(biāo)記庫 ( 簡稱 taglib) ,當(dāng)您擴(kuò)展項(xiàng)目或轉(zhuǎn)向另一個項(xiàng)目時您可以重復(fù)使用這些標(biāo)記。您還可以將 taglib 傳遞給其它開發(fā)人員,從而他們可以在自己的網(wǎng)站上使用,或者在您 Web 應(yīng)用程序的其它部分使用。
JSTL 的目標(biāo)是為了簡化 JSP 頁面的設(shè)計。對于頁面設(shè)計人員來說,使用腳本語言(默認(rèn)值是 JAVA 語言)操作動態(tài)數(shù)據(jù)是比較困難的,而采用標(biāo)簽和表達(dá)式語言相對容易一些, JSTL 的使用為頁面設(shè)計人員和程序開發(fā)人員的分工協(xié)作提供了便利。以下是JSP標(biāo)準(zhǔn)標(biāo)記庫JSTL的介紹。
一.配置 JSTL
包括兩個 JAR 文件, jstl.jar 和 standard.jar 。是什么沒有必要管,重在應(yīng)用( 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標(biāo)簽庫
Core 標(biāo)簽庫主要包括了一般用途的標(biāo)簽、條件標(biāo)簽、迭代標(biāo)簽和 URL 相關(guān)的標(biāo)簽。在 JSP 頁面使用 Core 標(biāo)簽,要使用 taglig 指令,指定引用的標(biāo)簽庫,如下:
- <%@ taglib rui=”http://java.sun.com/jsp/jstl/core” prefix=”c” %>
一般用途的標(biāo)簽有< c:out>、< c:set>、< c:remove>、< c:cath>
1.< c:out>
用于計算一個表達(dá)式并將結(jié)果輸出。類似于 JSP 中 < %=%> 表達(dá)式,或者是 EL 中 $ ${el-expression} 。
2.< c:set>
用于設(shè)置范圍變量的值或者 javabean 對象的屬性。
看個實(shí)際例子:
- < c:set var=”username” value=”lisi” scope=”session”/>
這樣就相當(dāng)于設(shè)置了 session 。
3.< c:remove>
相對 < c:set> 其作用是移除范圍變量。比如: < c:remove var=”nusername” scope=”session”/>
4.< c:catch>
用于捕獲在其中嵌套的操作所拋出的異常對象,并將異常信息保存到變量中。
我們將有可能拋出異常的代碼放置到開始標(biāo)簽 :< c:catch> 和結(jié)束標(biāo)簽 :< /c:catch> 之間。如果其中代碼出現(xiàn)異常,異常對象將被捕獲,保存在 var 聲明的變量中,該變量總是有 page 范圍。如果沒有發(fā)生異常,而 var 所標(biāo)識的范圍變量將被移除。
如果沒有指定 var 屬性,異常只是簡單的被捕獲,異常信息并不會被保存。
- <c:catch var=”exception”>
- <%
- int i = 5;
- int j = 0;
- int k=i/j;
- %>
- < SPAN>c:catch>
- <c:out value=”${exception}” /><br>
- <c:out value=”${exception.massage}”/>
條件標(biāo)簽包括< c:if>< c:choose>< c:when>< c:otherwise>
1.< c:choose>
< c:choose> 和 < c:when> 、 < c:otherwise> 一起實(shí)現(xiàn)互斥條件執(zhí)行,類似于 java 中的 if else.
< c:choose> 一般作為 < c:when> 、 < c:otherwise> 的父標(biāo)簽。
- <c:choose>
- <c:when test="${row.v_money<10000}">
- 初學(xué)下海
- < SPAN>c:when>
- <c:when test="${row.v_money>=10000&&row.v_money<20000}">
- 身手小試
- < SPAN>c:when>
- <c:otherwise>
- 商業(yè)能手
- < SPAN>c:otherwise>
- < SPAN>c:choose>
< c:choose> 操作的語法
- <c:choose>
- <c:whentestc:whentest="expression">
- bodycontent
- < SPAN>c:when>
- <c:whentestc:whentest="expression">
- bodycontent
- < SPAN>c:when>
- ...
- <c:otherwise>
- bodycontent
- < SPAN>c:otherwise>
- < SPAN>c:choose>
注意:每個要測試的條件都由相應(yīng)的 < c:when> 標(biāo)記來表示,至少要有一個 < c:when> 標(biāo)記。只會處理第一個其 test 值為 true 的 < c:when> 標(biāo)記體內(nèi)的內(nèi)容。如果沒有一個 < c:when> 測試返回 true ,那么會處理 < c:otherwise> 標(biāo)記的主體內(nèi)容。注:盡管如此, < c:otherwise> 標(biāo)記卻是可選的; < c:choose > 標(biāo)記至多可有一個嵌套的 < c:otherwise> 標(biāo)記
2.< c:if>
用于實(shí)現(xiàn) java 中的 if 語句功能。
- <c:if test=”${user.visitCount==1}”>
- This is your first visit .
- < SPAN>c:if>
若為true,會打印中間部分。也可以聲明var,方便下一步判斷。
迭代標(biāo)簽迭代標(biāo)簽有< c:forEach>和< /c:forEach>
- //遍歷記錄集
- <c:forEachitemsc:forEachitems="${finalResult.rows}"var="row">
- <trclasstrclass="<%=tdClass[(rank+1)%2]%>">
- <tdaligntdalign="center"><span><%=rank%>< SPAN>span>< SPAN>td>
- <tdaligntdalign="center"><span><c:outvaluec:outvalue="${row.player_name}"/>< SPAN>span>< SPAN>td>
- <tdaligntdalign="center"><span>¥<c:outvaluec:outvalue="${row.money}"/>< SPAN>span>< SPAN>td>
- < SPAN>tr>
- <%rank++;%>
- < SPAN>c:forEach>
- 也可以設(shè)定固定次數(shù)。
- <c:forEachvarc:forEachvar=”i”begin=”100“end=“110”>
- ${i}
- < SPAN>c:forEach>
- 如果再加個step=“2”那么每次增長為2。
三.sql標(biāo)簽
- 設(shè)置數(shù)據(jù)源:
- <sql:setDataSourcedataSourcesql:setDataSourcedataSource="proxool.breadTycoon"/>
- //將數(shù)據(jù)庫某查詢的結(jié)果聲明為一個變量
- <sql:queryvarsql:queryvar="finalResult">
- selectplayer_name,moneyfromtb_playerorderbymoneyDESCLIMIT10
- < SPAN>sql:query>
- 然后可以:
- <c:forEachitemsc:forEachitems="${finalResult.rows}"var="row"varStatus="s">
- advCosts[${s.index}]=${row.adv_cost};
- < SPAN>c:forEach>
- 數(shù)據(jù)更新標(biāo)簽:
- <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"/>
- < SPAN>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}"/>
- < SPAN>sql:query>
- <c:forEachitemsc:forEachitems="${queryAllChannelCount.rowsByIndex}"var="channelCN">
- <c:setvaluec:setvalue="${channelCN[0]}"var="channelTotal"/>
- < SPAN>c:forEach>
調(diào)用存儲過程更新數(shù)據(jù)庫:
- <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>
四.格式化標(biāo)簽
- <fmt:formatNumbervaluefmt:formatNumbervalue=”12.3”pattern=”.000”/>
- 將輸出12.300.應(yīng)用樣式”.000”,將使格式化后的小數(shù)部分有3位。不足3位將以0補(bǔ)齊。
- <fmt:formatDatevaluefmt:formatDatevalue=”<%=newjava.util.Date()%>”type=”date”/>
- 格式化的結(jié)果是:2007-5-27.
- <fmt:formatDatevaluefmt:formatDatevalue=”<%=newjava.util.Date()%>”type=”time”/>
- 格式化的結(jié)果是:9:25:11
- <fmt:formatDatevaluefmt:formatDatevalue=”<%=newjava.util.Date()%>”type=”both”/>
- 格式化的結(jié)果是:2007-5-279:25:11
【編輯推薦】