JSTL详解

来源:互联网 发布:phpstudy站点域名设置 编辑:程序博客网 时间:2024/05/17 07:59

JSTL详解

JSP 标准标记库(Java Standard Tag Library ) 是一组以标准化格式实现许多通用的 Web 站点功能的定制标记。

JSTL 的目标是为了简化 JSP 页面的设计。对于页面设计人员来说,使用脚本语言(默认值是 JAVA 语言)操作动态数据是比较困难的,而采用标签和表达式语言相对容易一些,JSTL 的使用为页面设计人员和程序开发人员的分工协作提供了便利。

1. 配置 JSTL  

1.包括两个 JAR 文件,jstl.jar standard.jar  

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 标签库,它主要包括了一般用途的标签、条件标签、迭代标签和 URL 相关的标签。

2.Core 标签库

Core 标签库主要包括了一般用途的标签、条件标签、迭代标签和 URL 相关的标签。在 JSP 页面使用 Core 标签,要使用 taglig 指令,指定引用的标签库,如下:

<%@ taglibrui=”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:removevar=”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 yourfirst 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:forEachitems="${finalResult.rows}"var="row">       

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

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

<tdalign="center"><span ><c:outvalue="${row.player_name}"/></span> </td>

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

</tr>

<%rank++;%>     

</c:forEach>  

也可以设定固定次数。

<c:forEach var=”i” begin=”100 “ end= “110”>

      ${i}

</c:forEach>

如果再加个 step= “2 ”那么每次增长为 2  

3.sql 标签

设置数据源 <sql:setDataSource dataSource="proxool.breadTycoon"/> // 将数据库某查询的结果声明为一个变量

<sql:query var="finalResult" >

   select player_name,money from tb_player order by money DESC LIMIT10   

</sql:query>

       然后可以:

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

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

   </c:forEach>

       数据更新标签:

<sql:update>  

          callproc_set_role_salespro(?,?,?,?,?);

          <sql:paramvalue="30"/>

          <sql:paramvalue="39"/>

          <sql:paramvalue="<%=spID%>"/>

          <sql:paramvalue="<%=productID%>"/>

          <sql:paramvalue="1"/>               

        </sql:update>

 

<sql:query var="queryAllChannelCount">

SELECT COUNT(*) astotal FROM tb_channel WHERE game_id=? AND begin_round<func_cur_round(?) ANDplayer_id=? AND channel_flag=0

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

<sql:paramvalue="${gameID}"/>

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

</sql:query>

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

       <c:setvalue="${channelCN[0]}" var="channelTotal"/>

</c:forEach>  

调用存储过程更新数据库:  

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

<c:forEachitems="${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:paramvalue="${paramValues.pro_sort[getparamsta.index]}"/>

<sql:paramvalue="${paramValues.price[getparamsta.index]}"/>

<sql:paramvalue="${paramValues.output[getparamsta.index]}"/>

<sql:param value="0"/>

</sql:update>

</c:forEach>

</c:if>

4.格式化标签  

主要用来格式话数字和日期的显示

1.<fmt: formatNumber value =”12.3” pattern=”.000”/>将输出 12.300. 应用样式 ”.000”, 将使格式化后的小数部分有 3 位。不足 3 位将以 0 补齐               2.<fmt:formatDatevalue=”<%=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>

文章引用自:http://zwh910621.javaeye.com/blog/516434

相关文章:(更详细的用法)

http://www.360doc.com/content/07/0117/11/16538_334194.shtml