EL表达式
EL 全名为Expression Language,是表达式语言。
EL表达式主要是代替jsp页面中的表达式脚本在jsp页面中进行数据的输出。因为EL表达式在输出数据的时候,要比jsp的表达式脚本要简洁很多。
不需要加任何jar包。不依赖任何其它库。提供了在脚本元素范围外使用运行表达式的功能。基本语法: ${expression}
(这样输出的结果相同)
(EL表达式在输出null值(比如key1)的时候,输出的是空串;jsp表达式脚本输出null值的时候,输出的是null字符串)
<%
request.setAttribute("key", "值");
%>
表达式脚本输出key的值是:<%=request.getAttribute("key")%> <br>
EL表达式输出key的值是:${key}
当四个域中都有相同的key的数据的时候,EL表达式会根据四个域的从小到大的顺序去进行搜索,找到就输出
1、输出复杂的Bean对象
EL表达式是不需要引入jstl.jar的
EL表达式中,找的不是这个属性,而是找这个属性所对应的get方法
输出map是输出花括号包裹的键值对;输出List得到的是由 [] 包裹起来的;输出数组得到的是首地址
<%
Person person = new Person();
person.setName("name111");
person.setPhones(new String[]{"123", "456", "789"});
List<String> cities = new ArrayList<String>();
cities.add("beijin");
cities.add("shanghai");
cities.add("shenzheng");
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("key_person", person);
%>
${ key_person } <br>
${ key_person.name } <br>
${ key_person.phones } <br>
${ key_person.phones[1] } <br>
${ key_person.cities } <br>
${ key_person.cities[1] } <br>
${ key_person.map } <br>
${key_person.map[key2]} <br>
2、关系运算、逻辑运算、算术运算
3、empty运算
${ empty key1 }
4、三元运算
${ 12 == 12 ? "123" : "456" }
5、点运算和中括号运算
.点运算,可以输出bean对象中某个属性的值
[]中括号运算,可以输出有序集合中某个元素的值
并且中括号运算还可以输出map集合中 key 里含有特殊字符的key的值(比如. 和 逻辑运算符)
6、11个EL隐含对象

(1)EL获取四个特定域的属性
要先在某个域中setAttribute
直接 ${ key1 } 是按四个域从小到大的顺序去搜索的
如果使用比如 ${ applicationScope.key1 } 我们就可以选择性地去搜索了
(2)pageContext演示
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${ pageContext } <br>
1、协议
<%--
request.getScheme() 可以获取请求的协议
--%>
<%=request.getScheme()%> <br> <%-- http --%>
${ pageContext.request.scheme } <br> <%-- 因为在el表达式中默认会找点后面内容所对应的"get"方法 --%> <%-- http --%>
2、请求的服务器ip或域名
<%=request.getServerName()%> <br> <%-- localhost --%>
${ pageContext.request.serverName } <br>
3、服务器端口
<%=request.getServerPort()%> <br>
${ pageContext.request.serverPort } <br>
4、获取当前的工程路径
<%=request.getContextPath()%> <br>
${ pageContext.request.contextPath } <br>
5、获取请求方法
<%=request.getMethod()%> <br>
${ pageContext.request.method } <br>
6、获取客户端ip地址
<%=request.getRemoteHost()%> <br>
${ pageContext.request.remoteHost } <br>
7、获取会话的id编号
<%=session.getId()%> <br>
${ pageContext.session.id } <br>
</body>
</html>
JSTL标签库
JSTL(JSP Standard Tag Library,核心标签库)是 JSP 标签的集合,它封装了 JSP 应用的通用核心功能。JSP标准标签库。
EL表达式主要是为了替换jsp中的表达式脚本,而标签库则是为了替换代码脚本。
JSP 标签是一组与 HTML 标签相似,但又比 HTML 标签强大的功能标签。JSTL 用来简化 JSP 开发,可以使我们不用嵌入 Java 代码就能够开发出复杂的 JSP 页面。

一、IDEA中使用JSTL
1、在jsp标签库中使用taglib指令引入标签库:
例如CORE标签库<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
其他四个同理,注意uri与上图中不同,用的是上图中的”前缀“
2、POM.xml 下导入坐标
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
二、c标签示例
1、赋值标签<c:set />
set标签可以往域中保存数据
域对象.setAttribute(key, value);
page表示PageContext域
request表示Request域
session表示Session域
application表示ServletContext域
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
保存之前:${ requestScope.abc } <br>
<c:set scope="request" var="abc" value="abcValue" />
保存之后:${ requestScope.abc } <br>
</body>
</html>

2、if标签<c:if />
if标签用来做if判断
test属性表示判断的条件(使用EL表达式输出)
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<c:if test="${ 12 == 12 }">
<h1>12 == 12</h1>
</c:if>
</body>
</html>
3、choose,when,otherwise标签
choose标签开始选择判断
when标签表示每一种判断情况(test属性表示当前这种判断情况的值
otherwise标签表示剩下的情况
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
request.setAttribute("height", 180);
%>
<c:choose>
<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>
<h2>剩下小于170的情况</h2>
</c:otherwise>
</c:choose>
</body>
</html>
4、foreach标签
items表示遍历的集合
var表示遍历到的数据
begin表示遍历的开始索引值
end表示结束的索引值
step表示遍历的步长值
(1)遍历1-10输出
<table>
<c:forEach begin="1" end="10" var="i">
<tr>
<td>第${ i }</td>
</tr>
</c:forEach>
</table>
(2)遍历Object数组
<%
request.setAttribute("arr", new String[]{"123", "456", "789"});
%>
<c:forEach items="${ requestScope.arr }" var="item">
${ item } <br>
</c:forEach>
(3)遍历map集合
<%
Map<String, Object> map = new HashMap<String, Object>();
map.put("key1", "value1");
map.put("key2", "value2");
map.put("key3", "value3");
request.setAttribute("map", map);
%>
<%-- for ( Map.Entry<String, Object> entry : map.entrySet()) --%>
<c:forEach items="${ requestScope.map }" var="entry">
<h1>${ entry } : ${ entry.key } = ${ entry.value }</h1>
</c:forEach>
(4)遍历list集合
<%
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>
<c:forEach 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> 删除、修改 </td>
</tr>
</c:forEach>
</table>



















