1.EL 表达式

a)什么是 EL 表达式,EL 表达式的作用?

EL 表达式的全称是:Expression Language。是表达式语言。
EL 表达式的什么作用:EL 表达式主要是代替 jsp 页面中的表达式脚本在 jsp 页面中进行数据的输出。
因为 EL 表达式在输出数据的时候,要比 jsp 的表达式脚本要简洁很多。

EL 表达式的格式是:${表达式}
EL 表达式在输出 null 值的时候,输出的是空串。jsp 表达式脚本输出 null 值的时候,输出的是 null 字符串。

b)EL 表达式搜索域数据的顺序

EL 表达式主要是在 jsp 页面中输出数据。
主要是输出域对象中的数据。
当四个域中都有相同的 key 的数据的时候,EL 表达式会按照四个域的从小到大的顺序去进行搜索,找到就输出。

c)EL 表达式输出 Bean 的普通属性,数组属性。List 集合属性,map 集合属性

  1. package com.atguigu.pojo;
  2. import java.util.Arrays;
  3. import java.util.List;
  4. import java.util.Map;
  5. public class Person {
  6. private String name;
  7. private String[] phones;
  8. private List<String> cities;
  9. private Map<String,Object> map;
  10. private int age =18;
  11. public Person() {
  12. }
  13. public Person(String name, String[] phones, List<String> cities, Map<String, Object> map) {
  14. this.name = name;
  15. this.phones = phones;
  16. this.cities = cities;
  17. this.map = map;
  18. }
  19. public String getName() {
  20. return name;
  21. }
  22. public void setName(String name) {
  23. this.name = name;
  24. }
  25. public String[] getPhones() {
  26. return phones;
  27. }
  28. public void setPhones(String[] phones) {
  29. this.phones = phones;
  30. }
  31. public List<String> getCities() {
  32. return cities;
  33. }
  34. public void setCities(List<String> cities) {
  35. this.cities = cities;
  36. }
  37. public Map<String, Object> getMap() {
  38. return map;
  39. }
  40. public void setMap(Map<String, Object> map) {
  41. this.map = map;
  42. }
  43. public int getAge() {
  44. return age;
  45. }
  46. public void setAge(int age) {
  47. this.age = age;
  48. }
  49. @Override
  50. public String toString() {
  51. return "Person{" +
  52. "name='" + name + '\'' +
  53. ", phones=" + Arrays.toString(phones) +
  54. ", cities=" + cities +
  55. ", map=" + map +
  56. '}';
  57. }
  58. }
  1. <%@ page import="com.atguigu.pojo.Person" %>
  2. <%@ page import="java.util.ArrayList" %>
  3. <%@ page import="java.util.List" %>
  4. <%@ page import="java.util.Map" %>
  5. <%@ page import="java.util.HashMap" %><%--
  6. Created by IntelliJ IDEA.
  7. User: 18725
  8. Date: 2022/3/15
  9. Time: 10:40
  10. To change this template use File | Settings | File Templates.
  11. --%>
  12. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  13. <html>
  14. <head>
  15. <title>Title</title>
  16. </head>
  17. <body>
  18. <%
  19. Person person = new Person();
  20. person.setName("张三");
  21. person.setPhones(new String[]{"123455","243656","3467787"});
  22. List<String> cities = new ArrayList<String>();
  23. cities.add("北京");
  24. cities.add("上海");
  25. cities.add("深圳");
  26. person.setCities(cities);
  27. Map<String,Object> map = new HashMap<>();
  28. map.put("key1","value1");
  29. map.put("key2","value2");
  30. map.put("key3","value3");
  31. person.setMap(map);
  32. pageContext.setAttribute("p", person);
  33. %>
  34. 输出 Person:${ p }<br/>
  35. 输出 Person 的 name 属性:${p.name} <br>
  36. 输出 Person 的 pnones 数组属性值:${p.phones[2]} <br>
  37. 输出 Person 的 cities 集合中的元素值:${p.cities} <br>
  38. 输出 Person 的 List 集合中个别元素值:${p.cities[2]} <br>
  39. 输出 Person 的 Map 集合: ${p.map} <br>
  40. 输出 Person 的 Map 集合中某个 key 的值: ${p.map.key3} <br>
  41. 输出 Person 的 age 属性:${p.age} <br>
  42. </body>
  43. </html>

本质是调用类中的getXxx()或isXxx()方法

d)EL 表达式——运算

语法:${ 运算表达式 } , EL 表达式支持如下运算符:
QQ截图20220315110016.png
QQ截图20220315110037.png
QQ截图20220315110059.png
i. empty 运算
empty 运算可以判断一个数据是否为空,如果为空,则输出 true,不为空输出 false。
以下几种情况为空:
<%
//
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 } <br/>
${ empty emptyStr } <br/>
${ empty emptyArr } <br/>
${ empty emptyList } <br/>
${ empty emptyMap } <br/>

ii. 三元运算
表达式 1?表达式 2:表达式 3
如果表达式 1 的值为真,返回表达式 2 的值,如果表达式 1 的值为假,返回表达式 3 的值。
${ 12 != 12 ? “国哥帅呆”:“国哥又骗人啦” }

iii. “.”点运算 和 [] 中括号运算符
.点运算,可以输出 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’] } <br>
${ map[“b+b+b”] } <br>
${ map[‘c-c-c’] } <br>

e)EL 表达式的 11 个隐含对象

EL 个达式中 11 个隐含对象,是 EL 表达式中自己定义的,可以直接使用。
变量 类型 作用
pageContext PageContextImpl 它可以获取 jsp 中的九大内置对象

pageScope Map 它可以获取 pageContext 域中的数据
requestScope Map 它可以获取 Request 域中的数据
sessionScope Map 它可以获取 Session 域中的数据
applicationScope Map 它可以获取 ServletContext 域中的数据

param Map 它可以获取请求参数的值
paramValues Map 它也可以获取请求参数的值,获取多个值的时候使用。

header Map 它可以获取请求头的信息
headerValues Map 它可以获取请求头的信息,它可以获取多个值的情况

cookie Map 它可以获取当前请求的 Cookie 信息
initParam Map 它可以获取在 web.xml 中配置的上下文参数

i. EL 获取四个特定域中的属性
pageScope ====== pageContext 域
requestScope ====== Request 域
sessionScope ====== Session 域
applicationScope ====== ServletContext 域

<%
pageContext.setAttribute(“key1”, “pageContext1”);
pageContext.setAttribute(“key2”, “pageContext2”);
request.setAttribute(“key2”, “request”);
session.setAttribute(“key2”, “session”);
application.setAttribute(“key2”, “application”);
%>
${ applicationScope.key2 }

ii. pageContext 对象的使用
1. 协议:
2. 服务器 ip:
3. 服务器端口:
4. 获取工程路径:
5. 获取请求方法:
6. 获取客户端 ip 地址:
7. 获取会话的 id 编号:
<%—
request.getScheme() 它可以获取请求的协议
request.getServerName() 获取请求的服务器 ip 或域名
request.getServerPort() 获取请求的服务器端口号
getContextPath() 获取当前工程路径
request.getMethod() 获取请求的方式(GET 或 POST)
request.getRemoteHost() 获取客户端的 ip 地址
session.getId() 获取会话的唯一标识
—%>
<%
pageContext.setAttribute(“req”, request);
%>
<%=request.getScheme() %> <br>

1.协议: ${ req.scheme }<br> //因为pageContext.setAttribute(“req”, request); <br>
//${ pageScope.req.scheme }<br>这种写法也行
2.服务器 ip:${ pageContext.request.serverName }<br>
3.服务器端口:${ pageContext.request.serverPort }<br>
4.获取工程路径:${ pageContext.request.contextPath }<br>
5.获取请求方法:${ pageContext.request.method }<br>
6.获取客户端 ip 地址:${ pageContext.request.remoteHost }<br>
7.获取会话的 id 编号:${ pageContext.session.id }<br>

iii. EL 表达式其他隐含对象的使用
param Map 它可以获取请求参数的值
paramValues Map 它也可以获取请求参数的值,获取多个值的时候使用。

输出请求参数 username 的值:${ param.username } <br>
输出请求参数 password 的值:${ param.password } <br>
输出请求参数 username 的值:${ paramValues.username[0] } <br>
输出请求参数 hobby 的值:${ paramValues.hobby[0] } <br>
输出请求参数 hobby 的值:${ paramValues.hobby[1] } <br>

请求地址:
http://localhost:8080/09_EL_JSTL/other_el_obj.jsp?username=wzg168&password=666666&hobby=java&hobby=cpp

header Map 它可以获取请求头的信息
headerValues Map 它可以获取请求头的信息,它可以获取多个值的情况
输出请求头【User-Agent】的值:${ header[‘User-Agent’] } <br>
输出请求头【Connection】的值:${ header.Connection } <br>
输出请求头【User-Agent】的值:${ headerValues[‘User-Agent’][0] } <br>

cookie Map 它可以获取当前请求的 Cookie 信息
获取 Cookie 的名称:${ cookie.JSESSIONID.name } <br>
获取 Cookie 的值:${ cookie.JSESSIONID.value } <br>

initParam Map 它可以获取在 web.xml 中配置的上下文参数
web.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>

2、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“ _%>

f) JSTL 标签库的使用步骤

1、先导入 jstl 标签库的 jar 包。
taglibs-standard-impl-1.2.1.jar
taglibs-standard-spec-1.2.1.jar
2、第二步,使用 taglib 指令引入标签库。
<%@ taglib prefix=”curi=”http://java.sun.com/jsp/jstl/core“ %>

g)core 核心库使用

i. (使用很少)
作用:set 标签可以往域中保存数据

<%—
i.
作用: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>

ii.
if 标签用来做 if 判断。
<%—
ii.
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>

iii. 标签
作用:多路判断。跟 switch … case …. default 非常接近
<%—
iii. 标签
作用:多路判断。跟 switch … case …. default 非常接近
choose 标签开始选择判断
when 标签表示每一种判断情况
test 属性表示当前这种判断情况的值
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**>

iv.
作用:遍历输出使用。

<%—1.遍历 1 到 10,输出
begin 属性设置开始的索引
end 属性设置结束的索引
var 属性表示循环的变量(也是当前正在遍历到的数据)
for (int i = 1; i < 10; i++)
—%>
<table border=”1”>
<c:forEach begin=”1” end=”10” var=”i”>
<tr>
<td>第${i}行</td>
</tr>
</c:forEach>
</table>


<%— 2.遍历 Object 数组
for (Object item: arr)
items 表示遍历的数据源(遍历的集合)
var 表示当前遍历到的数据
—%>
<%
request.setAttribute(“arr”, new String[]{“18610541354”,“18688886666”,“18699998888”});
%>
<c:forEach items=”${ requestScope.arr }” var=”item”>
${ item } <br>
</c:forEach>


  1. 遍历 Map 集合
    <%
    Map map = new HashMap();
    map.put(“key1”, “value1”);
    map.put(“key2”, “value2”);
    map.put(“key3”, “value3”);
    //
    for ( Map.Entry entry : map.entrySet()) {
    //
    }
    request.setAttribute(“map”, map);
    %>
    <c:forEach items=”${ requestScope.map }” var=”entry”>
    <h1>${entry.key} = ${entry.value}</h1>
    </c:forEach>

public class Student {
//4.编号,用户名,密码,年龄,电话信息
private Integer id;
private String username;
private String password;
private Integer age;
private String phone;

<%
List studentList = new ArrayList();
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>

  1. public interface LoopTagStatus {
  2. Object getCurrent();
  3. //表示获取当前遍历到的数据
  4. int getIndex();
  5. //表示获取遍历的索引
  6. int getCount();
  7. //表示遍历的个数
  8. boolean isFirst();
  9. //
  10. boolean isLast();
  11. //表示当前遍历到的数据是否是第一条,或最后一条
  12. Integer getBegin();
  13. //
  14. Integer getEnd();
  15. //
  16. Integer getStep();
  17. //获取begin,end,step属性值
  18. }

09尚硅谷_EL表达式&JSTL标签库王振国 - 课堂笔记.pdf