JSTL标签
导包:jstl.jar standard.jar
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
1.1 <c:out>标签
<c:out> 标签用于输出一段文本内容到pageContext对象当前保存的“out”对象中。
<c:out value="aabbcc<br/>" escapeXml="false"></c:out> <c:out value="<a href=''>点点</a>" escapeXml="true"></c:out> <% request.setAttribute("data",null); %> <c:out default="bbbbbbbbbbbbb" value="${data }"></c:out>
输出:
1.2 <c:set>标签
<c:set>标签用于把某一个对象存在指定的域范围内,或者设置Web域中的java.util.Map类型的属性对象或JavaBean类型的属性对象的属性。
<br/>_____________c:set___可操作各个域javabean Map集合____ <c:set var="dd" value="ddvalue" scope="page"/> ${dd }<br/> <% Map map=new HashMap(); request.setAttribute("map",map); %> <c:set property="dd" value="xxx" target="${map}" /> ${map.dd }<br/> <% Person p=new Person(); request.setAttribute("p",p); %> <c:set property="name" value="namevalue" target="${p}"></c:set> <c:out value="${p.name}"></c:out>
package cn.itcast.domain; public class Person { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } }
1.3 <c:remove>标签
<c:remove>标签用于删除各种Web域中的属性。
其语法格式如下:
<c:remove var="varName" [scope="{page|request|session|application}"] />
1.4 c:catch>标签
<c:catch>标签用于捕获嵌套在标签体中的内容抛出的异常,其语法格式如下:<c:catch [var="varName"]>nested actions</c:catch>
var属性用于标识<c:catch>标签捕获的异常对象,它将保存在page这个Web域中。
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=gb2312" %>
<c:catch var="myex">
<%
int i=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}" />
1.5 <c:if>标签
<c:if test=“”>标签可以构造简单的“if-then”结构的条件表达式
<c:if var="aaa" test="${user==null}" scope="page"></c:if>
1.6 <c:choose>标签
<c:choose>标签用于指定多个条件选择的组合边界,它必须与<c:when>和<c:otherwise>标签一起使用。使用<c:choose>,<c:when>和<c:otherwise>三个标签,可以构造类似 “if-else if-else” 的复杂条件判断结构。
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=gb2312" %>
<c:set value="${param.count}" var="count“ /> pageContext(count,2)
<c:choose>
<c:when test="${count == 0}">
对不起,没有符合您要求的记录。
</c:when>
<c:otherwise>
符合您要求的记录共有${count}条.
</c:otherwise>
</c:choose>
1.7 <c:forEach>标签
<c:forEach>标签用于对一个集合对象中的元素进行循环迭代操作,或者按指定的次数重复迭代执行标签体中的内容。
<br/>_____________c:foreach______ <c:forEach var="i" begin="1" end="9" step="1" > ${i } </c:forEach> <br/>___c:foreach 实现表格隔行变色______ <% List list=new ArrayList(); list.add("aaa"); list.add("bbb"); list.add("ccc"); list.add("ddd"); request.setAttribute("list",list); %> <style> .odd{background-color: blue;} .even{background-color: red;} tr:hover{background-color: green;} //如果不支持鼠标放上去变色,可从tomact默认网页上拷头<!DOCTYPE html> </style> <table> <c:forEach var="str" items="${list}" varStatus="status"> <tr class="${status.count%2==0?'even':'odd' }"><td> ${status} ::: ${str }</td></tr> </c:forEach> </table> <br/>____________________________________ <% String atts[] = new String [5]; atts[0]="hello"; atts[1]="this"; atts[2]="is"; atts[3]="a"; atts[4]="pen"; request.setAttribute("atts", atts); %> <c:forEach items="${atts}" var="item" varStatus="s"> <h2><c:out value="${item}"/> varStatus的四种属性:</h2> index:${s.index}</br> count:${s.count}</br> first:${s.first}</br> last:${s.last}</br> </c:forEach>
1.8 <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>标签的最大好处。
http://localhost:808/servlet/MyServlet?name=“中国”
示例:<c:param name="name" value="value" />
1.9 <c:url>标签
<c:url>标签用于在JSP页面中构造一个URL地址,其主要目的是实现URL重写。URL重写就是将会话标识号以参数形式附加在URL地址后面
<c:url var="url" value="/index.jsp"> <c:param name="name" value="中国"></c:param> </c:url> <a href="${url }">购买</a>
1.10 <c:redirect>标签
<c:redirect>标签用于将当前的访问请求转发或重定向到其他资源,它可以根据url属性所指定的地址,执行类似<jsp:forward>这个JSP标准标签的功能,将访问请求转发到其他资源;或执行response.sendRedirect()方法的功能,将访问请求重定向到其他资源。
<% String data="aa,bb,cc,dd"; request.setAttribute("data",data); %> <c:forTokens items="${data}" delims="\," var="c"> ${c } : </c:forTokens>