JSP标签库概述
JSP标准标签库(JSP Standard Tag Library,JSTL)是实现Web应用程序中常见的通用功能的定制标签库集,程序员使用JSTL标签来避免在JSP页面中使用脚本。
本章将介绍JSTL的应用基础、如何从表示层删除源代码来简化软件的维护。
JSTL概述
- JSTL英文全称是“JSP Standard Tag Library”,即JSP标准标签库之意。
- JSTL是由JCP(Java Commnunity Process)指定的标准规范,是一组形如html的标签,使得程序员即使不需要学习Java也可以编写动态Web页。自2002年中期发布后,它已成为JSP平台的一个标准组成部分。
- JSTL提供了诸如循环、条件、数据库访问、XML处理、国际化等开发上的工具和流程。
- 目前最新的版本为1.2,是一个正在不断开发和完善的开放源代码的JSP标签库,它支持多种标签。
- 在学习JSTL标签库之前,需要先下载JSTL所需要的JAR包。有两种获取方式
- 通过官方网站(http://www.apache.org/dist/jakarta/taglibs/standard)下载,获取API里面的jstl.jar、standard.jar。
- 使用MyEclipse自带的驱动包。使用MyEclipse创建Web工程时,选择“JSTL Support”选项。
- JSTL分成了5大类
Core标签库
- 核心标签库主要包括通用标签、条件标签、迭代标签和与URL相关的标签。
- 在使用Core标签库的JSP文件的开始部分,添加代码:<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
通用标签
<c:out>标签
- 用于将表达式的结果输出到当前的JspWriter对象中。其功能类似于JSP的表达式<%= %>,或者EL表达式${}。
- 语法
- <c:out value=“value” [default=“default value”] [escapeXml=“true|false”] />
- <c:out value=“value” [escapeXml=“true|false”] >default value </c:out>
- value:要输出的值,可以是EL表达式或常量
- default:value值为空时所输出的内容
- escapeXml:为true时,对输出内容中的<、>、“、‘和&字符进行转义,分别转成<、>、'、"和&
- value:要输出的值,可以是EL表达式或常量
- <c:out> 标签用于输出一段文本内容到pageContext对象当前保存的“out”对象中。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>通用标签out</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <!-- 第二种形式,单标签 --> <!-- value:要输出得值 --> <c:out value="value值"/> <br/> <!-- value有值,default不输出 --> <c:out value="value值" default="default默认值"/> <br> <!-- default:默认值 --> <c:out value="${name}" default="default默认值"/> <br> <c:out value="<hr>value值<hr>" default="default默认值"/> <br> <!-- escapeXml:是否原样输出,默认值为true,原样输出 --> <c:out value="<hr>value值<hr>" default="default默认值" escapeXml="true"/> <br> <!-- 把escapeXml设置成false,<hr>显示为分割线 --> <c:out value="<hr>value值<hr>" default="default默认值" escapeXml="false"/> <br> <br/> <hr/> <!-- 第二种形式,双标签 --> <br/> <br/> <!-- value:要输出得值 --> <c:out value="value值"> </c:out> <br/> <c:out value="value值"> default默认值 </c:out> <br> <!-- default:默认值 --> <c:out value="${name}"> default默认值 </c:out> <br> <c:out value="<hr>value值<hr>"> default默认值 </c:out> <br> <!-- escapeXml:是否原样输出,默认值为true,原样输出 --> <c:out value="<hr>value值<hr>" escapeXml="true"> default默认值 </c:out> <br> <!-- 把escapeXml设置成false,<hr>显示为分割线 --> <c:out value="<hr>value值<hr>" escapeXml="false"> default默认值 </c:out> </body> </html>
<c:set>标签
- <c:set>标签用于设置JSP页面的各种域范围中的变量,或者设置java.util.Map对象或JavaBean对象的属性。
- 语法
- <c:set value=“value” var=“name” [scope=“范围”]/>将value的值保存到名为name的变量中,同时name变量保存到选定的作用范围中。
- scope=“范围”:可以是page|request|session|application
- <c:set var=“name” [scope=“范围”] > value </c:set> 将标签体中的内容保存到名为name的变量中,同时name变量保存到选定的作用范围中。
- <c:set value=“value” var=“name” [scope=“范围”]/>将value的值保存到名为name的变量中,同时name变量保存到选定的作用范围中。
- <c:set value=“value” target=“target” property=“propertyName” />将value的值保存到target对象的propertyName属性中。
- <c:set target=“target” property=“propertyName”> value </c:set> 将标签体的内容保存到target对象的propertyName属性中。
- <c:set>标签用于把某一个对象存在指定的域范围内,或者设置Web域中的java.util.Map类型的属性对象或JavaBean类型的属性对象的属性。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>标准化通用标签set标签</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <% Map map = new HashMap(); request.setAttribute("map",map); %> <c:set value="向map添加值" target="${map}" property="key值"/> ${map.key值 } <hr/> <c:set var="body" scope="session"> body content </c:set> ${body } </body> </html>
<c:remove>标签
- <c:remove>标签用于移除JSP页面中指定域范围中的变量。
- 语法 <c:remove var=“name” [scope=“范围”]/>
- scope=“范围可以是page|request|session|application
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>标准化标签remove标签</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <c:set var="username" value="Tom"/> 输出:<c:out value="${username}"></c:out><br/> <c:remove var="username"/> 在输出:<c:out value="${username}" default="空"/> </body> </html>
<c:catch>标签
- <c:catch>标签用于捕获嵌套在标签体内的内容抛出的异常对象,并将异常信息保存到变量中。
- 语法 <c:catch [var=“name”]> body content </c:catch>
- 将可能发生异常的代码放到该标签中,如果发生异常,异常信息保存到name变量中。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>标准标签catch标签 </title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <c:catch var="myex"> <% int x=10/0; %> </c:catch> 异常:<c:out value="${myex}" /><br /> 异常 myex.getMessage:<c:out value="${myex.message}" /><br /> 异常 myex.getCause:<c:out value="${myex.cause}" /><br /> 异常 myex.getStackTrace:<c:out value="${myex.stackTrace}" /> </body> </html>
条件标签
<c:if>标签
- <c:if>标签用来做条件判断,功能类似于JSP中的<%if(boolean){}%>。
- 注意:对于判断标签的test属性,可以使用一些关系操作符,如==、!=、<、>、>=、<=等,也可以将这些关系操作符用eq、ne、lt、le、gt、ge取代
- <c:if test=“”>标签可以构造简单的“if-then”结构的条件表达式
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>标准标签,条件标签if</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <c:set var="username1" value="1"/> <c:if test="${username1==1}">条件成立</c:if> </body> </html>
<c:choose>、<c:when>、<c:otherwise>标签
- <c:choose>标签用于提供条件选择的上下文,它必须与<c:when>和<c:otherwise>标签一起使用。
- <c:when>作为<c:choose>的子标签,<c:when>有一个test属性,该属性的值为布尔型,如果test的值为true,则执行<c:when>标签体的内容。
- <c:otherwise>标签没有属性,它必须作为<c:choose>标签的最后分支出现。
- <c:choose>标签用于指定多个条件选择的组合边界,它必须与<c:when>和<c:otherwise>标签一起使用。使用<c:choose>,<c:when>和<c:otherwise>三个标签,可以构造类似 “if-else if-else” 的复杂条件判断结构。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>标准标签,条件标签choose</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <c:set var="score" value="89"/> <c:choose> <c:when test="${score>90}"> 优秀</c:when> <c:when test="${score>80 && score<90}"> 良好</c:when> <c:otherwise>不太好</c:otherwise> </c:choose> <hr/> <c:set value="${param.count}" var="count"></c:set> <c:choose> <c:when test="${count == 0}"> 对不起,没有符合您要求的记录。 </c:when> <c:otherwise> 符合您要求的记录共有${count}条. </c:otherwise> </c:choose> </body> </html>
迭代标签
<c:forEach>标签
- <c:forEach>标签用于对包含了多个对象的集合进行迭代,重复执行它的标签体,或者重复迭代固定的次数。
- 注意:
- items属性并不是一定要有的属性,但是当没有使用items属性时,就一定要使用begin和end属性。
- varStatus:用来保存现有遍历计数相关的信息。例如,如果varStatus=“i”,那么会将相应信息放到名称为i的变量中,i变量有四个属性值
- index:现在所操作的成员的索引
- count:所操作的成员总数
- first:现在所操作成员是否是第一个成员
- last:现在所操作成员是否是最后一个成员
- <c:forEach>标签用于对一个集合对象中的元素进行循环迭代操作,或者按指定的次数重复迭代执行标签体中的内容。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>标准标签,迭代标签foreach</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> <style type="text/css"> .odd{ background-color:white; } .even{ background-color:black; color:white; } tr:hover{background-color:pink;} </style> </head> <body> <% List list = new ArrayList(); list.add("aaa"); list.add("bbb"); list.add("ccc"); list.add("ddd"); list.add("eee"); list.add("fff"); request.setAttribute("list",list); %> <table border="1" width="40%"> <c:forEach var="str" items="${list}" varStatus="status"> <tr class="${status.count%2==0 ? 'even':'odd'}"><td>${str}</td><td>${status.count}</td></tr> </c:forEach> </table> </body> </html>
<c:forTokens>标签
- <c:forTokens>标签用来浏览一字符串中所有的成员,其成员是由定义符号(Delimiters)所分隔的。
<c:forTokens items=“a:b:c:d” delims=“:” var=“token”>
<c:out value=“${token}” /> <br>
</c:forTokens>
- 注意:这个标记的使用效果相当于java.util.StringTokenizer类。将字符串“a:b:c:d”以“:”分隔符分开,token是循环到当前所分割得到的字符串。
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>标准标签,迭代标签fortokens</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <c:forTokens items="(abcd)----(efgh)" delims="()" var="str"> <c:out value="${str}"/><br/> </c:forTokens> <hr/> <c:forTokens items="a:b:c:d" delims=":" var="token"> <c:out value="${token}"/><br/> </c:forTokens> </body> </html>
URL相关的标签
JSP网页开发中经常用到超链接、页面的包含和重定向等操作,在JSTL中,也提供了相应的标签来完成这些功能
这些标签包括<c:import>、<c:url>、<c:redirect>和<c:param>。
<c:import>标签:
- 可以把其他静态或者动态文件包含到本身的JSP页面中。
- 与JSP的动作<jsp:include>的区别在于:
- <jsp:include>只能包含和自己在同一个Web应用中的文件
- <c:import>不仅能包含和自己在同一个Web应用下的文件,还可包含其他Web应用或其他网站的文件。
- 属性
- url属性是必须要有的,它是用来设定被包含页面的地址,可以是绝对地址也可以是相对地址。
- url如果使用相对地址,把同一个Web应用中的文件引入的话,例如<c:import url=“MyHtml.html”/>
- 还可使用绝对路径,将其他网站的文件包含进来。例如<c:import url=“http://www.baidu.com” charEncoding=“gb2312”/>
- 当var属性存在时,把文件内容包含进来,但是它不输出到网页上,而是保存到var设定的变量中,而属性scope设定该变量的作用范围。
<c:url>标签
- <c:url>标签在JSP页面构造一个URL,它提供了3个功能元素
- 它们可以在URL前面附加当前Servlet上下文的名称
- 可以为会话管理重写URL
- 可以对请求参数名称和值进行URL编码,这些功能在为J2EE Web应用程序构造URL时特别有用。
- <c:url>标签用于在JSP页面中构造一个URL地址,其主要目的是实现URL重写。URL重写就是将会话标识号以参数形式附加在URL地址后面
- url.jsp:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>与URL有关的标签,url</title> </head> <body> <c:url value="/url2.jsp"></c:url><hr/> <!-- 有var,value值保存到var里,没有var,直接输出到屏幕 --> <c:url value="/url2.jsp" var="url"> </c:url> <a href="${url}">url2.jsp</a> </body> </html>
- 源代码:
<c:redirect>标签
- <c:redirect>标签用于向用户的浏览器发送HTTP重定向响应,它是JSTL中与 javax.servlet.http.HttpServletResponse的sendRedirect()方法功能相当的标记。
- <c:redirect>标签用于实现请求重定向
<c:param>标签
- <c:param>标签的作用是为一个URL添加请求参数,在前面的<c:url>、<c:redirect>和<c:import>标签中都已经见过<c:param>的用法。
- 在JSP页面进行URL的相关操作时,经常要在URL地址后面附加一些参数。<c:param>标签可以嵌套在<c:import>、<c:url>或<c:redirect>标签内,为这些标签所使用的URL地址附加参数。
- <c:param>标签在为一个URL地址附加参数时,将自动对参数值进行URL编码,例如,如果传递的参数值为“中国”,则将其转换为“%d6%d0%b9%fa”后再附加到URL地址后面,这也就是使用<c:param>标签的最大好处。
- 示例:<c:param name="name" value="value" />
param.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>与URL有关的标签,param</title> </head> <body> <c:url value="./url2.jsp" var="url"> <c:param name="username2" value="aaa"></c:param> </c:url> <a href="${url}">url.jsp</a> </body> </html>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>url2</title>
</head>
<body>
<%
//获取url.jsp的值
String str = request.getParameter("username2");
out.println(str);
%>
</body>
</html>
param.jsp源文件
url2.jsp