1.什么是JSTL
JSTL(标准标签库)是apache对EL表达式的扩展(也就是说JSTL依赖EL),JSTL是标签语言!JSTL标签使用以来非常方便,它与JSP动作标签一样,只不过它不是JSP内置的标签,需要我们自己导包,以及指定标签库而已!core:核心标签库,我们学习的重点; fmt:格式化标签库
2.使用taglib指令导入标签库
在我们使用这些标签库之前,必须在JSP页面顶部使用<%@taglib%>指令定义引用的标签库和访问前缀 1.下面是导入JSTL的core标签库: <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core" %> prefix="c":指定标签库的前缀,这个前缀可以随便给值,但大家都会在使用core标签库时指定前缀为c; uri="http://java.sun.com/jstl/core":指定标签库的uri(如果引入在线库的话,查看服务器里面有没有jstl的java包,否则会找不到),它不一定是真实存在的网址,但它可以让JSP找到标签库的描述文件;2.在JSP页面顶端通过taglib 标签库引入: <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> 注意:uri跟之前的c标签的不一样
3.标签
core标签库常用标签——>也被成为"c标签"
<c:out>:输出
>value:可以是字符串常量,也可以是EL表达式
>default:当要输出的内容为null时,会输出default指定的值
>escapeXml:默认值为true,表示转义成!
<c:set>:设置(创建域的属性)
> var:变量名
> value:变量值,可以是EL表达式
> scope:域,默认为page,可选值:page、request、session、application
语法 | 说明 |
<c:set var=”a” value=”hello”/> | 在pageContext中添加name为a,value为hello的数据。 |
<c:set var=”a” value=”hello” scope=”session”/> | 在session中添加name为a,value为hello的数据。 |
<c:remove>:删除域变量
> var:变量名
> scope:如果不给出scope,表示删除所有域中的该名称的变量;如果指定了域,那么只删除该域的变量。
语法 | 说明 |
<% pageContext.setAttribute("a", "pageContext"); request.setAttribute("a", "session"); session.setAttribute("a", "session"); application.setAttribute("a", "application"); %> <c:remove var="a"/> | 删除所有域中name为a的数据! |
<c:remove var="a" scope=”page”/> | 删除pageContext中name为a的数据! |
<c:url>
* value:指定一个路径!它会在路径前面自动添加项目名。
如:<c:url value="/jstl1.jsp"/>,它会输出/JSTLDemo/jstl1.jsp
* 子标签:<c:param>,用来给url后面添加参数,例如:
如:<c:url value="/jstl1.jsp"><c:param name=“username” value=“user”/><!—会对参数进行url编码--> </c:url> 结果为:/JSTLDemo/jstl1.jsp?username=user
* var:指定变量名,一旦添加了这个属性,那么url标签就不会再输出到页面,而是把生成url保存到域中。
* scope:它与var一起使用,用来保存url。
语法 | 说明 |
<c:url value="/"/> | 输出上下文路径:/JSTLDemo/ |
<c:url value="/" var="a" scope="request"/> | 把本该输出的结果赋给变量a。范围为request |
<c:url value="/AServlet"/> | 输出:/JSTLDemo/AServlet |
<c:url value="/AServlet"> <c:param name="username" value="abc"/> <c:param name="password" value="123"/> </c:url> | 输出:/JSTLDemo/AServlet?username=abc&password=123如果参数中包含中文,那么会自动使用URL编码! |
<c:if>——>对应java中的if语句
*test:必须是一个boolean类型的值,如果test的值为true,那么执行if标签的内容,否则不执行。
*var:用于指定变量名,该变量用于保存test属性的判断结果。如果该变量不存在就创建它并存入域里面。 *scope:用于指定变量的有效范围,默认为page。
例如: <c:set var="a" value="hello"/>[在page域中创建名为a的变量]
<c:if test="${not empty a[判断a变量不为null,没有指定域,表示全域] }" var="flag"(储存true或者false)>
<c:out value="${a }"/>
</c:if>
<c:choose>——>对应java中的if······else if·······else语句 when标签的test为true时,会执行这个when的内容。当所有when标签的test都为false时,才会执行otherwise标签的内容。
*<c:when>条件测试标签,可以存在多个
*test:为条件表达式,必须要有
*<c:otherwise>其他条件标签,必须定义在<c:when>标签的后面
例如: <c:set var="score" value="30"/>
<c:choose>
<c:when test="${score > 100 || score < 0}">错误的分数: ${score }</c:when> 相当于if
<c:when test="${score >= 90 }">A级</c:when> 相当于else if
<c:when test="${score >= 80 }">B级</c:when> 相当于else if
<c:when test="${score >= 70 }">C级</c:when> 相当于else if
<c:when test="${score >= 60 }">D级</c:when> 相当于else if
<c:otherwise>E级</c:otherwise> 相当于else
</c:choose>
<c:forEach>
它可以用来计数方式来循环,它也可以用来循环遍历数组、集合!
* var:循环变量
* begin:设置循环变量从几开始。(包含。
* end:设置循环变量到几结束)
* step:设置步长!等同与java中的i++,或i+=2。step默认为1
计数方式: for(int i = 1; i <= 10; i++) { }
等同于: <c:forEach var="i" begin="1" end="10"> </c:forEach>
输出数组、集合:
* items:指定要循环谁,它可以是一个数组或一个集合
* var:把数组或集合中的每个元素赋值给var指定的变量。
<% String [] strs={“a”,”b”,”c”}; request.setAttribute(“strs”,strs); %>
<c:forEach items="${strs }" var="str"> ${str }<br/> </c:forEach>
结果: a b c
等同于
for(String str : strs) { }
遍历Map容器:
<%Map<String,String> stu = new LinkedHashMap<String,String>(); stu.put("number", "N_1001"); stu.put("name", "zhangSan"); stu.put("age", "23");stu.put("sex", "male");pageContext.setAttribute("stu", stu); %>
<c:forEach var="item" items="${stu }"> <%-- 因为遍历的是Map,所以每一项是Entry类型 --%>
<c:out value="${item.key } : ${item.value }"/><br/> <%-- 获取Entry的key和value --%>
</c:forEach>
* varStatus 循环的状态变量
* count:循环元素的个数
* index:循环元素的下标
* first:是否为第一个元素 * last:是否为最后一个元素
* current:当前元素
例如: <% List list =new ArrayList();list.add("一"); list.add("二");request.setAttribute("list",list);%> <c:forEach items="${list }" varStatus="vs">
内容:${vs.current } 下标:${vs.index} 第几个:${vs.count } 是否是第一个:${vs.first }是否是最后一 个:${vs.last }
</c:forEach>
<fmt:formatDate>格式化时间
* value:指定一个Date类型的变量
* pattern:用来指定输出的模板!
例如:<% Date date = new Date(); pageContext.setAttribute("d", date); %>
<fmt:formatDate value="${d}" pattern="yyyy-MM-dd HH:mm:ss"/> <%--按指定格式输出日期和时间.--%>
<fmt:formatNumber>格式化数字:
* value:指定要格式化的值
* pattern:用来指定输出的模板!例如”0.00”或者“#.##”
例如: <% request.setAttribute(“num”,3.16); %>
<%--根据pattern定义的格式保留小数点后几位,它会四舍五入!如果不足,会以0补位--%>
<fmt:formatNumber value="${num1}" pattern="0.000">
<%-- 根据pattern定义的格式保留小数点后几位,它会四舍五入!如果不足,不会补位 --%>
<fmt:formatNumber value="${num1}" pattern="#.###">
结果: 3.160 3.16