JSTL
什么是JSTL
JSTL(JSP Standard Tag Library,JSP标准标签库)是一个不断完善的开放源代码的JSP标签库,是由apache的jakarta小组来维护的。JSTL1.1必须在Servlet2.4和JSP2.0以上的容器才能正常工作。
为了抑制JSP里写大量的JA V A代码,所以用JSTL标签来实现JA V A里逻辑调用,JSP 标准标记库(JSP Standard Tag Library,JSTL)是一个实现 Web 应用程序中常见的通用功能的定制标记库集,这些功能包括迭代和条件判断、数据管理格式化、XML 操作以及数据库访问。
JSTL包括五个标签库,即Core标签库、XML标签库、国际化与格式化标签库和SQL标签库,
JSTl的使用
一.配置 JSTL
两个 JAR 文件, jstl.jar 和 standard.jar 。
原文引入:
<%@ taglib prefix="c" uri="java.sun/jsp/jstl/core" %>
<%@ taglib prefix="sql" uri="java.sun /jsp /jstl/sql" %>
<%@ taglib prefix="fmt" uri="java.sun /jsp /jstl/fmt" %> 二. Core 标签库(经常用)
Core 标签库主要包括了一般用途的标签、条件标签、迭代标签和 URL 相关的标签。在JSP 页面使用 Core 标签,要使用 taglig 指令,指定引用的标签库,如下:
<%@ taglib uri=”java.sun/jsp/jstl/core”  prefix=”c” %>
一般用途的标签有 <c:out> 、 <c:set> 、 <c:remove> 、 <c:catch>
1.<c:out>
用于计算一个表达式并将结果输出。类似于 JSP 中 <%=%> 表达式,或者是 EL 中$ ${el-expression} 。
但它有比较好用的default(如果返回的值为NULL),escapeXml(true/false)属性。<c:out value="${hello}"/>
2.<c:set>
用于设置范围变量的值或者 javabean 对象的属性。
看个实际例子:
可以声明变量并给它赋值,如:
<c:set value="hello" var="temp"/>
temp:${temp }
也可以设置一个对象的属性,如:
<c:set var=”username” value=”lisi” scope=”session”/>
这样就相当于设置了 session 。
3.<c:remove>
相对 <c:set> 其作用是移除范围变量。比如:
<c:remove var=”username” 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}”/>
后一句相当于: Message()
条件标签包括 <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’}” var=”result”/>
<c:out value=”${result}” />
2.<c:choose>
<c:choose> 和 <c:when> 、 <c:otherwise> 一起实现互斥条件执行,类似于 java 中的 if else.
<c:choose> 一般作为 <c:when> 、 <c:otherwise> 的父标签。
eg :
jstl常用标签有哪些<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:forTokens>
1.<c:forEach>
// 遍历记录集
<table border="1">
<tr>
<td>姓名</td>
<td>年龄</td>
<td>所属组</td>
</tr>
<c:choose>
<c:when test="${empty userlist}">
<tr>
<td colspan="3">没有符合条件的数据!</td>
</tr>
</c:when>
<c:otherwise>
<c:forEach items="${userlist}" var="u">
<tr>
<td>${u.username }</td>
<td>${u.age }</td>
<td>${u.group.name }</td>
</tr>
</c:forEach>
</c:otherwise>
</c:choose>
</table>
也可以通过varStatus属性获得其状态值
<c:forEach items="${userlist}" var="u" varStatus="vs">
<tr>
<td>编号:${vs.count }</td>
<td>姓名:${u.username }</td>
<td>年龄:${u.age }</td>
<td>所属组:${u.group.name }</td>
</tr>
</c:forEach>
也可以设定固定次数。
<c:forEach var =”i” begin=”100 “ end= “110”>
${i}
</c:forEach>
如果再加个 step= “ 2 ”那么每次增长为 2 。
2.<c:forTokens>
<c:set var="strTokens"value="test,forTokens">
<c:forTokens items="${strTokens}" delims="," var="v">
}<br>
${v
</c:forTokens>
结果为:
test
forTokens
其它:<c:import>、<c:url>和<c:param>、<c:redirect>
1、<c:import>
相当于JSP中的<jsp:include>
<c:import url="localhost:8080/top.jsp"/>
2、<c:url>和<c:param>
通过<c:url>和<c:param>配合传递参数
<c:url value="localhost:8080/test.jsp" var="v"> <c:param name="username" value="willian"/>
<c:param name="password" value="123"/>
</c:url>
${v}
结果为:
localhost:8080/test.jsp?username=willian&password=123 3、<c:redirect>
相当于重定向
<c:redirect context="/shopping" url="/index.jsp"/>
三. 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="${ws}" 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="${wsByIndex}" 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}"/>

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。