EL表达式和JSTL标签库
EL表达式
EL表达式概述
含义:EL 表达式的全称是:Expression Language。是表达式语言。
作用:EL表达式主要是代替jsp 页面中的表达式脚本在jsp 页面中进行数据的输出。因为EL 表达式在输出数据的时候,要比jsp的表达式脚本要简洁很多。
格式:${表达式}
EL 表达式在输出null 值的时候,输出的是空串("")。jsp 表达式脚本输出null 值的时候,输出的是null字符串。
EL表达式的使用
输出域对象中的数据
EL 表达式主要是在jsp 页面中输出域对象中的数据。
EL表达式输出域的顺序(当四个域中有相同的key时):
按域范围的从小到大进行输出,小范围的域有数据就不输出大范围域中的数据了。
<%
//往四个域中都保存了相同key的数据
//按域的从小到大的顺序输出
session.setAttribute("key","session");
pageContext.setAttribute("key","pageContext");
request.setAttribute("key","request");
application.setAttribute("key","application");
%>
<!-- 此时输出的是:pageContext-->
${key}
EL表达式输出JavaBean类中的属性
属性数据类型 | 输出方式 |
---|---|
普通属性 | 对象.属性 |
数组属性 | 对象.属性[index] |
List属性 | 对象.属性[index] |
Map属性 | 对象.属性.key |
<%
Person person = new Person();
person.setName("拯救苍生");
person.setPhones(new String[]{"12414325252","134142414141"});
List<String> cities = new ArrayList<>();
cities.add("北京");
cities.add("上海");
cities.add("深圳");
person.setCities(cities);
Map<String,Object> map = new HashMap<>();
map.put("key1","value1");
map.put("key2","value2");
map.put("key3","value3");
person.setMap(map);
pageContext.setAttribute("person",person);
%>
输出Person:${person}<br/>
输出Person的name属性:${person.name}<br/>
输出Person的phones个别属性值:${person.phones[1]}<br/>
输出Person的cities集合属性值:${person.cities}<br/>
输出Person的cities某个属性值:${person.cities[1]}<br/>
输出Person的map集合属性值:${person.map}<br/>
输出Person的map集合某个属性值:${person.map.key1}<br/>
输出Person的age属性值:${person.age}<br/>
EL表达式运算符
关系运算符
关系运算符 | 说明 | 示例 | 结果 |
---|---|---|---|
== 或eq | 等于 | ${ 5 == 5 } 或${ 5 eq 5 } | true |
!= 或ne | 不等于 | ${ 5 !=5 } 或${ 5 ne 5 } | false |
< 或lt | 小于 | ${ 3 < 5 } 或${ 3 lt 5 } | true |
> 或gt | 大于 | ${ 2 > 10 } 或${ 2 gt 10 } | false |
<= 或le | 小于等于 | ${ 5 <= 12 } 或${ 5 le 12 } | true |
>= 或ge | 大于等于 | ${ 3 >= 5 } 或${ 3 ge 5 } | false |
逻辑运算符
逻辑运算符 | 说明 | 示例 | 结果 |
---|---|---|---|
&& 或and | 与运算 | ${ 12 == 12 && 12 < 11 } 或${ 12 == 12 and 12 < 11 } | false |
|| 或or | 或运算 | ${ 12 == 12 || 12 < 11 } 或${ 12 == 12 or 12 < 11 } | true |
! 或not | 取反运算 | ${ !true } 或${not true } | false |
算数运算符
算数运算符 | 说明 | 示例 | 结果 |
---|---|---|---|
+ | 加法 | ${ 12 + 18 } | 30 |
- | 减法 | ${ 18 - 8 } | 10 |
* | 乘法 | ${ 12 * 12 } | 144 |
/ 或div | 除法 | ${ 144 / 12 } 或${ 144 div 12 } | 12 |
% 或mod | 取模 | ${ 144 % 10 } 或${ 144 mod 10 } | 4 |
三元运算
格式:表达式1?表达式2:表达式3
如果表达式1 的值为真,返回表达式2 的值,如果表达式1 的值为假,返回表达式3 的值。
${12 == 12? “12==12”:“12!=12”}
[]运算符和.运算符
.点运算,可以输出Bean 对象中某个属性的值。
[]中括号运算,可以输出有序集合中某个元素的值。
[]中括号运算,还可以输出map集合中key里含有特殊字符的值。
<%
Map<String,Object> map = new HashMap<>();
map.put("a.","aValue");
map.put("b+","bValue");
map.put("c-","cValue");
request.setAttribute("map",map);
%>
<!--错误输出,因为有key中含有特殊字符"." ${map.a.}-->
${map['a.']}<br>
${map["b+"]}<br>
${map['c-']}<br>
empty运算
empty 运算可以判断一个数据是否为空,如果为空,则输出true,不为空输出false。
以下几种情况为空:
- 值为null值的时候,为空
- 值为空串的时候,为空
- 值是Object类型数组,长度为零的时候
- List集合,元素个数为零
- Map集合,元素个数为零
<%
request.setAttribute("emptyNull",null);
request.setAttribute("emptyStr","");
request.setAttribute("emptyArr",new Object[]{});
List<String> list = new ArrayList<>();
request.setAttribute("emptyList",list);
Map<String , Object> map = new HashMap<>();
request.setAttribute("emptyMap",map);
%>
<!-- 以下输出全为true-->
${empty emptyNull} <br>
${empty emptyNull} <br>
${empty emptyArr} <br>
${empty emptyList} <br>
${empty emptyMap} <br>
EL表达式的11个隐含对象
EL 个达式中11 个隐含对象,是EL 表达式中自己定义的,可以直接使用。
变量名 | 变量类型 | 作用 |
---|---|---|
pageContext | PageContextImpl | 它可以获取jsp 中的九大内置对象 |
pageScope | Map<String,Object> | 它可以获取pageContext 域中的数据 |
requestScope | Map<String,Object> | 它可以获取Request 域中的数据 |
sessionScope | Map<String,Object> | 它可以获取Session 域中的数据 |
applicationScope | Map<String,Object> | 它可以获取ServletContext 域中的数据 |
param | Map<String,String> | 它可以获取请求参数的值 |
paramValues | Map<String,String[]> | 它也可以获取请求参数的值,获取多个值的时候使用。 |
header | Map<String,String> | 它可以获取请求头的信息 |
headerValues | Map<String,String[]> | 它可以获取请求头的信息,它可以获取多个值的情况 |
cookie | Map<String,Cookie> | 它可以获取当前请求的Cookie 信息 |
initParam | Map<String,String> | 它可以获取在web.xml 中配置的<context-param>上下文参数 |
EL获取四个特定域中的属性
<%
pageContext.setAttribute("key1","pageContext1");
pageContext.setAttribute("key2","pageContext2");
request.setAttribute("key2","request");
session.setAttribute("key2","session");
application.setAttribute("key2","application");
%>
${applicationScope.key2}
<%-- {key2=request} --%>
${requestScope}
<%-- 输出一堆application的信息--%>
${applicationScope["javax.servlet.context.tempdir"]}
${applicationScope}
pageContext对象的使用
pageContext可以获取jsp中的九大内置对象。
所以可以常用来执行以下操作:
<%--
request.getScheme()可以获取请求的协议
request.getServerName()获取请求的服务器ip或域名
request.getServerPort()获取请求的服务器端口号
request.getContextPath()获取当前工程路径
request.getMethod()获取请求的方式(GET或POST)
request.getRemoteHost()获取客户端的IP地址
sessioin.getId()获取客户端的IP地址
--%>
<%
pageContext.setAttribute("req",request);
%>
<%=request.getScheme()%><br>
协议:${req.scheme}<br/>
服务器IP:${pageContext.request.serverName}<br/>
服务器端口号:${pageContext.request.serverPort}<br/>
获取工程路径:${pageContext.request.contextPath}<br/>
获取请求方法:${pageContext.request.method}<br/>
获取客户端的IP地址:${pageContext.request.remoteHost}<br/>
获取会话的ID编号:${pageContext.session.id}<br/>
EL表达式其他对象的使用
变量名 | 变量类型 | 作用 |
---|---|---|
param | Map<String,String> | 它可以获取请求参数的值 |
paramValues | Map<String,String[]> | 它也可以获取请求参数的值,获取多个值的时候使用。 |
输出请求参数username的值:${param.username}<br>
输出请求参数password的值:${param.password}<br>
输出请求参数username的值:${paramValues.username[0]}<br/>
输出请求参数hobby的值:${paramValues.hobby[0]}<br>
输出请求参数hobby的值:${paramValues.hobby[1]}<br>
变量名 | 变量类型 | 作用 |
---|---|---|
header | Map<String,String> | 它可以获取请求头的信息 |
headerValues | Map<String,String[]> | 它可以获取请求头的信息,它可以获取多个值的情况 |
输出请求头【User-Agent】的值:${header["User-Agent"]}<br>
输出请求头【Connection】的值:${header.connection}<br>
输出请求头【Connection】的值:${headerValues.CONNECTION[0]}<br>
变量名 | 变量类型 | 作用 |
---|---|---|
cookie | Map<String,Cookie> | 它可以获取当前请求的Cookie 信息 |
${cookie}<br>
获取Cookie的名称:${cookie.JSESSIONID.name}<br>
获取Cookie的值:${cookie.JSESSIONID.value}<br>
变量名 | 变量类型 | 作用 |
---|---|---|
initParam | Map<String,String> | 它可以获取在web.xml 中配置的<context-param>上下文参数 |
XML配置信息:
<context-param>
<param-name>username</param-name>
<param-value>root</param-value>
</context-param>
<context-param>
<param-name>url</param-name>
<param-value>jdbc:mysql:///test</param-value>
</context-param>
输出<Context-param>username的值:${initParam.username}<br>
输出<Context-param>url的值:${initParam.url}<br>
JSTL标签库
JSTL (JSP Standard Tag Library) JSP 标准标签库。是一个不断完善的开放源代码的JSP 标签库。
EL 表达式主要是为了替换jsp 中的表达式脚本,而标签库则是为了替换代码脚本。这样使得整个jsp 页面变得更佳简洁。
JSTL五个不同功能的标签库:
功能范围 | URI | 前缀 |
---|---|---|
核心标签库–重点 | http://java.sun.com/jsp/jstl/core | c |
格式化 | http://java.sun.com/jsp/jstl/fmt | fmt |
函数 | http://java.sun.com/jsp/jstl/functions | fn |
数据库(不使用) | http://java.sun.com/jsp/jstl/sql | sql |
XML(不使用) | http://java.sun.com/jsp/jstl/xml | x |
在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" %>
core核心库使用
- <c:set />(使用很少)
作用:set 标签可以往域中保存数据
<%--
1.<c:set/>
作用:set标签可以往域中保存数据
域对象:setAttribute(key,value);
scope属性设置保存到哪个域
page表示PageContext域(默认值)
request表示Request域
session表示Session域
application表示ServletContext域
var属性设置key是多少
value属性设置value是多少
--%>
保存之前:${requestScope.abc}<br/>
<c:set scope="request" var="abc" value="abcValue"/>
保存之后:${requestScope.abc}<br/>
<hr>
- <c:if />
if 标签用来做if 判断。
<%--
2.<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>
<hr>
- <c:choose> <c:when> <c:otherwise>标签
作用:多路判断。跟switch … case … default 非常接近
<%--
3.<c:choose> <c:when> <c:otherwise> 标签
作用:多路判断。跟switch...case...default非常接近
choose标签开始选择判断
when标签表示每一种判断情况
test表示当前判断情况的值
otherwise标签表示剩下的情况
<c:choose> <c:when> <c:otherwise> 标签使用时注意的情况
1、标签里不能使用html注释,要使用jsp注释
2、when标签的父标签只能是choose标签
--%>
<%
request.setAttribute("height",124);
%>
<c:choose>
<%-- jsp注释--%>
<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>小人</h3>
</c:when>
<c:when test="${requestScope.height>150}">
<h3>微人</h3>
</c:when>
<c:when test="${requestScope.height>140}">
<h3>纳人</h3>
</c:when>
<c:otherwise>
<h3>皮人</h3>
</c:otherwise>
</c:choose>
</c:otherwise>
</c:choose>
- <c:forEach />
作用:遍历输出使用。
<%-- 1.遍历1-10
begin属性设置开始的索引
end属性设置结束的索引
var 表示循环的变量(也是当前正在遍历到的数据)
for(i = 1;i <= 10;i++)
--%>
<table border="1" cellspacing="0">
<c:forEach begin="1" end="10" var="i">
<tr>
<th>第${i}行</th>
</tr>
</c:forEach>
</table>
<hr>
<%-- 2.遍历Object数组
for(Object o : arr)
items 表示遍历的数据源(遍历的集合)
var表示当前遍历到的数据
--%>
<%
request.setAttribute("arr",new String[]{"18610541354","188464842115","87542132"});
%>
<c:forEach items="${requestScope.arr}" var="item">
${item}<br>
</c:forEach>
<hr>
<%
Map<String , Object> map = new HashMap<>();
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">
${entry.key} ---> ${entry.value}<br>
</c:forEach>
<hr>
<%-- 4.遍历List集合==list中存放Student类,有编号,用户名,密码,年龄,电话属性--%>
<%
List<Student> studentsList = new ArrayList<>();
for (int i = 1; i <= 10; i++) {
studentsList.add(new Student(i,"username" + i,"password"+i,18+i,"phone"+i));
}
request.setAttribute("stus",studentsList);
%>
<table>
<tr>
<th>编号</th>
<th>用户名</th>
<th>密码</th>
<th>年龄</th>
<th>电话</th>
<th>操作</th>
</tr>
<%--
items表示遍历的集合
var表示遍历到的数据
begin表示遍历开始的索引(从零开始)
end表示遍历结束的索引
step属性表示遍历的步长值
varStatus属性表示当前遍历到的数据的状态
status.current表示当前遍历到的数据
status.index表示当前索引
status.count表示遍历的个数
status.first表示当前遍历的数据是否是第一条
status.last表示当前遍历的数据是否是最后一条
status.begin获取begin属性值
status.end获取end属性值
status.step获取step属性值
for(int i = 0 ;i < 10 ;i+=2)
--%>
<c:forEach begin="0" end="5" 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>