JSTL 标签库 全称是指 JSPStandardTagLibrary JSP 标准标签库。是一个不断完善的开放源代码的 JSP 标 签库。 EL 表达式主要是为了替换 jsp 中的表达式脚本,而标签库则是为了替换代码脚本。这样使得整个 jsp 页面 变得更佳简洁。
1)在 jsp 标签库中使用 taglib 指令引入标签库
- CORE 标签库 <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
- XML 标签库<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>
- FMT 标签库<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
- SQL 标签库 <%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>
- FUNCTIONS 标签库 <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
2)JSTL 标签库的使用步骤
1、先导入 jstl 标签库的 jar 包。
taglibs-standard-impl-1.2.1.jar taglibs-standard-spec-1.2.1.jar
2、第二步,使用 taglib 指令引入标签库。
3、core 核心库使用
i. <c:set/>(使用很少)
作用:set 标签可以往域中保存数据
<body>
<%--
i. <c:set/>
作用: set 标签可以往域中保存数据
域对象. setAttribute(key, value);
scope属性设置保存到哪个域
page表示PageContext域(默认值)
request表示Request域
session表示Session域
application表示ServletContext域
var属性设置key是多少
value属性设置值
--%>
保存之前:${ sessionScope.abc } <br>
<c:set scope="session" var="abc" value="abcValue"/>
保存之后:${ sessionScope.abc } <br>
</body>
ii. <c:if/>
if 标签用来做 if 判断。
<body>
<%--
ii.<c:if />
if标签用来做if判断。
test属性表示判断的条件(使用EL表达式输出)
--%>
<c:if test="${ 12 == 12 }">
<h1>12等于12</h1>
</c:if>
<c:if test="${ 12 != 12 }">
<h1>12不等于12</h1>
</c:if>
</body>
iii. <c:choose><c:when><c:otherwise>标签
作用:多路判断。跟 switch...case....default 非常接近
<body>
<%--
iii. <c:choose> <c:when> <c:otherwise>标签
作用:多路判断。跟switch ... case .... default非常接近
choose标签开始选择判断
when标签表示每. - 种判断情况
test属性表示当前这种判断情况的值
otherwise标签表示剩下的情况
kc:choose> <c:when> <c: otherwise>标签使用时需要注意的点:
1、标签里不能使用htmL注释,要使用jsp注释
2、when标签的父标签一定要是choose标签
--%>
<%
request.setAttribute("height", 180);
%>
<c:choose>
<%--这是htmL注释--%>
<c:when test="${ requestScope.height > 190 }">
<h2>小巨人</h2>
</c:when>
<c:when test="${ requestScope.height > 180 }">
<h2>很高</h2>
</
c:when>
<c:when test="${ requestScope.height > 170 }">
<h2>还可以</h2>
</c:when>
<c:otherwise>
<c:choose>
<c:when test=" ${requestScope.height > 160}">
<h3>大于160</h3>
</c :when>
<c:when test="${requestScope.height > 150}">
<h3>大于150</h3>
</c:when>
<c:when test="${requestScope.height > 140}">
<h3>大于140</h3>
</c:when>
<c:otherwise>
其他小于140
</c:otherwise>
</c:choose>
</c:otherwise>
</c:choose>
</body>
iv. <c:forEach/>
作用:遍历输出使用。
1. 遍历 1 到 10,输出
示例代码:
<body>
<%--1.遍历1到10,输出
begin属性设置开始的索引
end属性设置结束的索引
var属性表示循环的变量(也是当前正在遍历到的数据)
for(inti=1;i<10;i++)
--%>
<table border="1">
<c:forEach begin="1" end="10" var="i">
<tr>
<td>第${i}行</td>
</tr>
</c:forEach>
</table>
</body>
2. 遍历 Object 数组
示例代码:
<body>
<%-- 2.遍历0bject数组
for (0bject item: arr)
items表示遍历的数据源(遍历的集合)
var表示当前遍历到的数据
--%>
<%
request. setAttribute("arr", new String[ ]{"123123","456456" , "789789"});
%>
<c:forEach items="${ requestScope.arr }" var="item">
${item}<br>
</c:forEach>
</body>
3. 遍历 Map 集合
示例代码:
<body>
<%
Map<String, Object> map = new HashMap<String, Object>();
map.put("key1", "value1");
map.put("key2", "value2");
map.put("key3", "value3");
// for (Map.Entry<String, Object> entry : map.entrySet()){}
request.setAttribute("map", map);
%>
<c:forEach items="${requestScope.map}" var="entry">
<h3> ${entry.key} : ${entry.value} </h3>
</c:forEach>
</body>
4. 遍历 List 集合---list 中存放 Student 类,有属性:编号,用户名,密码,年龄,电话信息
Student 类:
public class Student {
//4.编号,用户名,密码,年龄,电话信息
private Integer id;
private String username;
private String password;
private Integer age;
private String phone;
}
示例代码:
<body>
<%--
4.遍历List集合---list中存放Student类,
有属性:编号,用户名,密码,年龄,电话信息
--%>
<%
List<Student> studentList = new ArrayList<Student>();
for (int i = 1; i <= 10; i++) {
studentList.add(new Student(i,"username"+i ,"pass"+i,18+i,"phone"+i));
}
request.setAttribute("stus", studentList);
%>
<table>
<tr>
<th>编号</th>
<th>用户名</th>
<th>密码</th>
<th>年龄</th>
<th>电话</th>
<th>操作</th>
</tr>
<%--
items 表示遍历的集合
var 表示遍历到的数据
begin 表示遍历的开始索引值
end 表示结束的索引值
step 属性表示遍历的步长值
varStatus 属性表示当前遍历到的数据的状态
for ( int i = 1; i < 10; i+=2 )
--%>
<c:forEach begin="2" end="7" step="2" varStatus="status" items="${requestScope.stus}" var="stu">
<tr>
<td>${stu.id}</td>
<td>${stu.username}</td>
<td>${stu.password}</td>
<td>${stu.age}</td>
<td>${stu.phone}</td>
<td>${status.step}</td>
</tr>
</c:forEach>
</table>
</body>