JSTL 學習、應用記錄

原來一直沒有看過,我說過我是新手,可是好多資料上彷佛也不重視 JSTL 。我看項目源代碼發現其中使用到了這個標籤庫,感受其還真是方便,頁面看起來更加清爽。減小了 JAVA 程序員親自寫的代碼量,還真驗證了,不懶不作程序員,程序員若是寫代碼不想着偷懶,那麼生活是很無趣的。 java

下面總結總結,學習學習。:) 程序員

JSP 標準標記庫( Standard Tag Library , JSTL) 是一組以標準化格式實現許多通用的 Web 站點功能的定製標記。 sql

JSP 技術的優點之一在於其定製標記庫工具。除了核心 JSP 標記,如 jsp:include 以外,定製標記庫工具使您可以建立惟一的標記來描述以站點或應用程序爲導向的操做。一旦您建立了定製標記庫 ( 簡稱 taglib) ,當您擴展項目或轉向另外一個項目時您能夠重複使用這些標記。您還能夠將 taglib 傳遞給其它開發人員,從而他們能夠在本身的網站上使用,或者在您 Web 應用程序的其它部分使用。 數據庫

      

       JSTL 的目標是爲了簡化 JSP 頁面的設計。對於頁面設計人員來講,使用腳本語言(默認值是 JAVA 語言)操做動態數據是比較困難的,而採用標籤和表達式語言相對容易一些, JSTL 的使用爲頁面設計人員和程序開發人員的分工協做提供了便利。 express

 

一. 配置 JSTL session

 

包括兩個 JAR 文件, jstl.jar 和 standard.jar 。是什麼沒有必要管,重在應用( 1+1 ? =2 ,咱們沒有必要深究,只須要知道這麼用就行。)。 jsp

 

原文引入: 工具

<%@ 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 屬性,異常只是簡單的被捕獲,異常信息並不會被保存。

Eg :

<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}」/>

後一句至關於: exception.getMessage()

 

條件標籤包括 <c:if><c:choose><c:when><c:otherwise>

1.<c:if>

用於實現 java 中的 if 語句功能。

 

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

       This is your first visit .

</c:if>

 

若爲 true ,會打印中間部分。也能夠聲明 var ,方便下一步判斷。

<c:if test=」${param.name==’admin’}」 value=」result」/>

<c:out value=」${result}」 />

 

2.<c:choose>

<c:choose> 和 <c:when> 、 <c:otherwise> 一塊兒實現互斥條件執行,相似於 java 中的 if else.

<c:choose> 通常做爲 <c:when> 、 <c:otherwise> 的父標籤。

eg :

<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:forEach> 和 </c:forEach>

 

// 遍歷記錄集

<c:forEach items="${finalResult.rows}" var="row">       

<tr class="<%=tdClass[(rank+1)%2]%>">

<td align="center"><span><%=rank%> </span></td>

<td align="center"><span ><c:out value="${row.player_name}"/></span> </td>

<td align="center"><span > ¥ <c:out value="${row.money}"/></span></td>

</tr>

<%rank++;%>     

</c:forEach> 

 

也能夠設定固定次數。

<c:forEach var =」i」 begin=」100 「 end= 「110」>

       ${i}

</c:forEach>

若是再加個 step= 「 2 」那麼每次增加爲 2 。

 

三. sql 標籤

 

設置數據源:

<sql:setDataSource dataSource="proxool.breadTycoon" />

// 將數據庫某查詢的結果聲明爲一個變量

<sql:query var="finalResult" >

    select player_name,money from tb_player order by money DESC LIMIT 10   

</sql:query>

       而後能夠:

  <c:forEach items="${ finalResult.rows}" var="row" varStatus="s">

        advCosts[${s.index}]=${row.adv_cost};

   </c:forEach>

       數據更新標籤:

<sql:update>  

                call proc_set_role_salespro(?,?,?,?,?);

                <sql:param value="30"/>

                <sql:param value="39"/>

                <sql:param value="<%=spID%>"/>

                <sql:param value="<%=productID%>"/>

                <sql:param value="1"/>               

            </sql:update>

 

<sql:query var="queryAllChannelCount">

SELECT COUNT(*) as total FROM tb_channel WHERE game_id=? AND begin_round<func_cur_round(?) AND player_id=? AND channel_flag=0

<sql:param value="${gameID}"/>

<sql:param value="${gameID}"/>

<sql:param value="${playerID}"/>

</sql:query>

<c:forEach items="${queryAllChannelCount.rowsByIndex}" var="channelCN">

       <c:set value="${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: formatNumber value =」12.3」 pattern=」.000」/>

將輸出 12.300. 應用樣式 」.000」, 將使格式化後的小數部分有 3 位。不足 3 位將以 0 補齊。

 

       <fmt:formatDate value=」<%=new java.util.Date() %>」 type=」date」 />

       格式化的結果是: 2007-5-27 .

<fmt:formatDate value=」<%=new java.util.Date() %>」 type=」time」 />

格式化的結果是: 9:25:11

<fmt:formatDate value=」<%=new java.util.Date() %>」 type=」both」 />

格式化的結果是: 2007-5-27 9:25:11

 

 

 

補充知識點:

 

1. 替換 request.getParameter("test"):

<c:if test="${param.test!=null}" >

<c:out value="${param.test}" />

</c:if>

 

2. <c:redirect url="a.jsp">

 

3.<c:redirect url="/max.jsp" context="/ch16">

<c:param name="name1" value="665"/>

<c:param name="name3" value=" 斯蒂芬 "/>

</c:redirect>

 

4.<c:forTokens items="zhangsan:lisi:as" delims=":" var="name">

${name}

</c:forTokens>

相關文章
相關標籤/搜索