目录
1.EL 表达式简介
2.EL 表达式搜索域数据的顺序
3.EL 表达式输出Bean的普通属性数组,List集合,map集合的属性。
4.EL 表达式——运算
4.1)关系运算
4.2)逻辑运算
4.3)算数运算
4.3.1、empty运算
4.3.2、三元运算
4.3.3、“.”点运算 和 [] 中括号运算符
5.EL 表达式的11个隐含对象
5.1)EL 获取四个特定域中的属性
5.2)pageContext对象的使用
5.3)EL表达式其他隐含对象的使用
EL 表达式的全称是:Expression Language。是表达式语言。
EL 表达式的什么作用:EL 表达式主要是代替 jsp 页面中的表达式脚本在 jsp 页面中进行数据的输出。
因为 EL 表达式在输出数据的时候,要比 jsp 的表达式脚本要简洁很多。
<%
request.setAttribute("key", "值");
%>
表达式脚本输出 key 的值是:
<%=request.getAttribute("key1") == null ? "" : request.getAttribute("key1")%>
EL 表达式输出 key 的值是:${key1}
EL 表达式的格式是:${表达式}
EL 表达式在输出 null 值的时候,输出的是空串。jsp 表达式脚本输出 null 值的时候,输出的是 null 字符串。
EL 表达式主要是在 jsp 页面中输出数据。
主要是输出域对象中的数据。
当四个域中都有相同的 key 的数据的时候,EL 表达式会按照四个域的从小到大的顺序去进行搜索,找到就输出。
<%
//往四个域中都保存了相同的key的数据。
request.setAttribute("key", "request");
session.setAttribute("key", "session");
application.setAttribute("key", "application");
pageContext.setAttribute("key", "pageContext");
%>
${ key }
练习:输出 Person 类中普通属性,数组属性。list 集合属性和 map 集合属性。
Person类:
package pojo;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
/**
* @author LIXICHEN
* @create 2020-04-22 18:05
*/
public class Person {
private String name;
private String[] phones;
private List cities;
private Map map;
public Person() {
}
public Person(String name, String[] phones, List cities, Map map) {
this.name = name;
this.phones = phones;
this.cities = cities;
this.map = map;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String[] getPhones() {
return phones;
}
public void setPhones(String[] phones) {
this.phones = phones;
}
public List getCities() {
return cities;
}
public void setCities(List cities) {
this.cities = cities;
}
public Map getMap() {
return map;
}
public void setMap(Map map) {
this.map = map;
}
@Override
public String toString() {
return "Person{" +
"name=" + name +
", phones=" + Arrays.toString(phones) +
", cities=" + cities +
", map=" + map +
'}';
}
}
输出代码:
<%@ page import="pojo.Person" %>
<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.Map" %>
<%@ page import="java.util.HashMap" %><%--
Created by IntelliJ IDEA.
User: Administrator
Date: 2020/4/22
Time: 18:08
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
练习
<%
Person person = new Person();
person.setName("小明");
person.setPhones(new String[]{"13611112222","18722223333","18699998888"});
List cities = new ArrayList<>();
cities.add("北京");
cities.add("上海");
cities.add("深圳");
person.setCities(cities);
Map map=new HashMap<>();
map.put("key1","value1");
map.put("key2","value2");
map.put("key3","value3");
map.put("key4","value4");
person.setMap(map);
pageContext.setAttribute("person",person);
%>
输出Person:${ person }
输出Person中的name属性值:${ person.name }
输出Person中的phones数组属性值:${ person.phones[0] }
输出Person中的cities集合中的元素值:${ person.cities }
输出Person中的cities集合中的个别元素值:${ person.cities[0] }
输出Person中的map集合:${ person.map }
输出Person中的map集合中某个key的值:${ person.map.key1 }
结果截图:
语法:${ 运算表达式 } , EL 表达式支持如下运算符:
empty 运算可以判断一个数据是否为空,如果为空,则输出 true,不为空输出 false。
以下几种情况为空:
1、值为 null 值的时候,为空
2、值为空串的时候,为空
3、值是 Object 类型数组,长度为零的时候
4、list 集合,元素个数为零
5、map 集合,元素个数为零
代码示例:
<%
// 1、值为null值的时候,为空
request.setAttribute("emptyNull", null);
// 2、值为空串的时候,为空
request.setAttribute("emptyStr", "");
// 3、值是Object类型数组,长度为零的时候
request.setAttribute("emptyArr", new Object[]{});
// 4、list集合,元素个数为零
List list = new ArrayList<>();
// list.add("abc");
request.setAttribute("emptyList", list);
// 5、map集合,元素个数为零
Map map = new HashMap();
// map.put("key1", "value1");
request.setAttribute("emptyMap", map);
%>
${ empty emptyNull }
${ empty emptyStr }
${ empty emptyArr }
${ empty emptyList }
${ empty emptyMap }
表达式 1?表达式 2:表达式 3
如果表达式 1 的值为真,返回表达式 2 的值,如果表达式 1 的值为假,返回表达式 3 的值。
代码示例:
${ 12 != 12 ? "嘿嘿嘿":"嘻嘻嘻" }
.点运算,可以输出 Bean 对象中某个属性的值。
[]中括号运算,可以输出有序集合中某个元素的值。并且[]中括号运算,还可以输出 map 集合中 key 里含有特殊字符的 key 的值。
代码示例:
<%
Map map = new HashMap();
map.put("a.a.a", "aaaValue");
map.put("b+b+b", "bbbValue");
map.put("c-c-c", "cccValue");
request.setAttribute("map", map);
%>
${ map['a.a.a'] }
${ map["b+b+b"] }
${ map['c-c-c'] }
代码示例:
<%
pageContext.setAttribute("key1", "pageContext1");
pageContext.setAttribute("key2", "pageContext2");
request.setAttribute("key2", "request");
session.setAttribute("key2", "session");
application.setAttribute("key2", "application");
%>
${ applicationScope.key2 }
代码示例:
<%--
request.getScheme() 它可以获取请求的协议
request.getServerName() 获取请求的服务器ip或域名
request.getServerPort() 获取请求的服务器端口号
getContextPath() 获取当前工程路径
request.getMethod() 获取请求的方式(GET或POST)
request.getRemoteHost() 获取客户端的ip 地址
session.getId() 获取会话的唯一标识
--%>
<%
pageContext.setAttribute("req", request);
%>
<%=request.getScheme() %>
1.协议: ${ req.scheme }
2.服务器ip:${ pageContext.request.serverName }
3.服务器端口:${ pageContext.request.serverPort }
4.获取工程路径:${ pageContext.request.contextPath }
5.获取请求方法:${ pageContext.request.method }
6.获取客户端ip地址:${ pageContext.request.remoteHost }
7.获取会话的id编号:${ pageContext.session.id }
结果截图:
web.xml配置
username
root
url
jdbc:mysql:///test
代码示例:
输出请求参数username的值:${ param.username }
输出请求参数password的值:${ param.password }
输出请求参数username的值:${ paramValues.username[0] }
输出请求参数hobby的值:${ paramValues.hobby[0] }
输出请求参数hobby的值:${ paramValues.hobby[1] }
输出请求头【User-Agent】的值:${ header['User-Agent'] }
输出请求头【Connection】的值:${ header.Connection }
输出请求头【User-Agent】的值:${ headerValues['User-Agent'][0] }
获取Cookie的名称:${ cookie.JSESSIONID.name }
获取Cookie的值:${ cookie.JSESSIONID.value }
输出<Context-param>username的值:${ initParam.username }
输出<Context-param>url的值:${ initParam.url }