当前位置: 代码迷 >> JavaScript >> JSTL 学习、施用记录
  详细解决方案

JSTL 学习、施用记录

热度:592   发布时间:2012-10-20 14:12:48.0
JSTL 学习、应用记录

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

?

?

原文链接: http://www.blogjava.net/JAVA-HE/archive/2007/05/27/120344.html