JSTL使用简述


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

JSP技术的优势之一在于其定制标记库工具。除了核心JSP标记,如jsp:include 之外,定制标记库工具使您能够创建唯一的标记来描述以站点或应用程序为导向的操作。一旦您创建了定制标记库(简称taglib),当您扩展项目或转向另一个项目时您可以重复使用这些标记。您还可以将taglib传递给其它开发人员,从而他们可以在自己的网站上使用,或者在您Web应用程序的其它部分使用。

      JSTL的目标是为了简化JSP 页面的设计。对于页面设计人员来说,使用脚本语言(默认值是JAVA语言)操作动态数据是比较困难的,而采用标签和表达式语言相对容易一些,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属性,异常只是简单的被捕获,异常信息并不会被保存。

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><span><%=rank%> </span></td>

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

<td><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>