EL 表达式
介绍以及作用
EL 表达式的全称是:Expression Language。是表达式语言。
EL 表达式的什么作用:
EL 表达式主要是代替 jsp 页面中的表达式脚本在 jsp 页面中进行数据的输出。 因为 EL 表达式在输出数据的时候,要比 jsp 的表达式脚本要简洁很多。
例子:
<body>
<% request.setAttribute("key1","值"); %>
表达式脚本输出 key 的值是:
<%=request.getAttribute("key1")==null?"":request.getAttribute("key1")%><br/>
EL 表达式输出 key 的值是:
${key1}
</body>
EL 表达式的格式是:${表达式}
EL 表达式在输出 null 值的时候,输出的是空串。jsp 表达式脚本输出 null 值的时候,输出的是 null 字符串。
EL 表达式搜索域数据的顺序
EL 表达式主要是在 jsp 页面中输出数据。
主要是输出域对象中的数据。
当四个域中都有相同的 key 的数据的时候,EL 表达式会按照四个域的从小到大的顺序去进行搜索,找到就输出。
EL 表达式输出 Bean的属性
例子:
//Bean类
package my;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class Me {
private String name;
private String[] phones;
private List<String> cities;
private Map<String,Object> map;
private int age=18;
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Me() {
}
public Me(String name, String[] phones, List<String> cities,
Map<String, Object> map) {
super();
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<String> getCities() {
return cities;
}
public void setCities(List<String> cities) {
this.cities = cities;
}
public Map<String, Object> getMap() {
return map;
}
public void setMap(Map<String, Object> map) {
this.map = map;
}
@Override
public String toString() {
// TODO Auto-generated method stub
return name+" "+phones+" "+cities+" "+map+" "+age ;
}
}
//jsp输出
<%@ page language="java" import="java.util.* ,java.lang.String , my.Me" pageEncoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
</head>
<body>
<% Me person = new Me();
person.setName("name");
person.setPhones(new String[]{"1861054","1866666","18688"});
List<String> cities = new ArrayList<String>();
cities.add("北京");
cities.add("上海");
cities.add("深圳");
person.setCities(cities);
Map<String,Object>map = new HashMap<String,Object>();
map.put("key1","value1");
map.put("key2","value2");
map.put("key3","value3");
person.setMap(map);
pageContext.setAttribute("p", person); %>
输出 Person:${ p }<br/>
输出 Person 的 name 属性:${p.name} <br>
输出 Person 的 pnones 数组属性值:${p.phones[2]}
<br> 输出 Person 的 List 集合中的元素值:${p.cities} <br>
输出 Person 的 List 集合中个别元素值:${p.cities[2]} <br>
输出 Person 的 Map 集合: ${p.map} <br>
输出 Person 的 Map 集合中某个 key 的值: ${p.map.key3} <br>
输出 Person 的 age 属性:${p.age} <br>
</body>
</html>
小结:
1.EL表达式输出Bean属性时,不是找的某个属性,而是找摸个属性对应的get方法:比如把例子中Me类的age属性删除,getAge方法返回18,则在jsp中返回18。
2.如果想让EL表达式Bean整体输出的话,相应的Bean类需要覆盖toString()方法。
EL 表达式之运算
语法:${ 运算表达式 }
例子:
${ 12>13&& 13>14}
1.关系运算
2.逻辑运算
3.算数运算
4.empty 运算
empty 运算可以判断一个数据是否为空,如果为空,则输出 true,不为空输出 false。
以下几种情况为空:
1、值为 null 值的时候,为空
2、值为空串的时候,为空
3、值是 Object 类型数组,长度为零的时候
4、list 集合,元素个数为零
5、map 集合,元素个数为零
例子:
${ empty emptyNull }
5.三元运算
表达式 1?表达式 2:表达式 3
如果表达式 1 的值为真,返回表达式 2 的值,如果表达式 1 的值为假,返回表达式 3 的值。
例子:
${ 12 != 12 ? "正确":"错误" }
6.“.”点运算 和 [] 中括号运算符
.点运算,可以输出 Bean 对象中某个属性的值。
[]中括号运算,可以输出有序集合中某个元素的值。 并且[]中括号运算,还可以输出 map 集合中 key 里含有特殊字符的 key 的值。
例子:
${ map.a } <br>
${ map['a.a.a'] } <br>
EL 表达式的 11 个隐含对象
EL 个达式中 11 个隐含对象,是 EL 表达式中自己定义的,可以直接使用。
EL 获取四个特定域中的属性
pageScope ====== pageContext 域
requestScope ====== Request 域
sessionScope ====== Session 域
applicationScope ====== ServletContext 域
例子:
<body>
<%
application.setAttribute("key2", "application"); %>
${ applicationScope.key2 }
${applicationScope}
</body>
pageContext 对象的使用
- 协议:
- 服务器 ip:
- 服务器端口:
- 获取工程路径:
- 获取请求方法:
- . 获取客户端 ip 地址:
- 获取会话的 id 编号:
<%-- request.getScheme() 它可以获取请求的协议
request.getServerName() 获取请求的服务器 ip 或域名
request.getServerPort() 获取请求的服务器端口号
getContextPath() 获取当前工程路径
request.getMethod() 获取请求的方式(GET 或 POST)
request.getRemoteHost() 获取客户端的 ip 地址
session.getId() 获取会话的唯一标识 --%>
<%=request.getScheme() %> <br>
1.协议: ${ pageContext.request.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>
EL 表达式其他隐含对象的使用
param Map<String,String> 它可以获取请求参数的值
paramValues Map<String,String[]> 它也可以获取请求参数的值,获取多个值的时候使用。
示例代码:
输出请求参数 username 的值:${ param.u } <br>
输出请求参数 password 的值:${ param.p } <br>
输出请求参数 hobby 的值:${ paramValues.h[0] } <br>
输出请求参数 hobby 的值:${ paramValues.h[1] } <br>
header Map<String,String> 它可以获取请求头的信息
headerValues Map<String,String[]> 它可以获取请求头的信息,它可以获取多个值的情况
例子:
输出请求头【User-Agent】的值:${ header['User-Agent'] } <br>
输出请求头【Connection】的值:${ header.Connection } <br>
输出请求头【User-Agent】的值:${ headerValues['User-Agent'][0] } <br>
cookie Map<String,Cookie> 它可以获取当前请求的 Cookie 信息
例子
获取 Cookie 的名称:${ cookie.JSESSIONID.name } <br>
获取 Cookie 的值:${ cookie.JSESSIONID.value } <br>
initParam Map<String,String> 它可以获取在 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</param-value>
</context-param>
//jsp
输出<Context-param>username 的值:${ initParam.username } <br>
输出<Context-param>url 的值:${ initParam.url } <br>
JSTL 标签库
介绍
JSTL 标签库 全称是指 JSP Standard Tag Library JSP 标准标签库。是一个不断完善的开放源代码的 JSP 标 签库。
EL 表达式主要是为了替换 jsp 中的表达式脚本,而标签库则是为了替换代码脚本。这样使得整个 jsp 页面 变得更佳简洁
JSTL 由五个不同功能的标签库组成。
在 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 标签可以往域中保存数据
例子:
<c:set scope="session" var="abc" value="abcValue"/>
保存之后:${ sessionScope.abc } <br>
//page 表示 PageContext 域(默认值) request 表示 Request 域
//session 表示 Session 域 application 表示
// ServletContext 域 var 属性设置 key value 属性设置值
<c:if />
if 标签用来做 if 判断。
例子:
<c:if test="${ 12 == 12 }">
<h1>12 等于 12</h1>
</c:if>
<c:if test="${ 12 != 12 }">
<h1>12 不等于 12</h1>
</c:if>
//if 标签用来做 if 判断。
//test 属性表示判断的条件(使用 EL 表达式输出)
<c:choose> <c:when> <c:otherwise>标签
作用:多路判断。跟 switch … case … default 非常接近
例子:
<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>
// choose 标签开始选择判断
// when 标签表示每一种判断情况
// test 属性表示当前这种判断情况的值
// otherwise 标签表示剩下的情况
// 标签使用时需要注意的点:
// 1、标签里不能使用 html 注释,要使用 jsp 注释
// 2、when 标签的父标签一定要是 choose 标签
<c:forEach />
作用:遍历输出使用
注意:
1、标签里不能使用 html 注释,要使用 jsp 注释
2、when 标签的父标签一定要是 choose 标签
1. 遍历 1 到 10,输出
例子:
// choose 标签开始选择判断
// when 标签表示每一种判断情况
// test 属性表示当前这种判断情况的值
// otherwise 标签表示剩下的情况
// 标签使用时需要注意的点:
<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>
3. 遍历 Map 集合
示例代码:
<% 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">
<h1>${entry.key} = ${entry.value}</h1>
</c:forEach>
- 遍历 List 集合—list 中存放 Me 类,有属性:用户名, 电话信息
例子:
public class Me {
private String name;
private String phones;
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 Me(String name, String phones) {
super();
this.name = name;
this.phones = phones;
}
@Override
public String toString() {
// TODO Auto-generated method stub
return name+" "+phones+" " ;
}
}
//jsp
<%@ page language="java" import="java.util.* ,java.lang.String , my.Me" pageEncoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
</head>
<body>
<%--4.遍历 List 集合---list 中存放 Me 类,有属性:用户名,电话信息--%>
<% List<Me> studentList = new ArrayList<Me>();
for (int i = 1; i <= 10; i++)
{ studentList.add(new Me("username"+i ,"phone"+i)); }
request.setAttribute("stus", studentList); %>
<table>
<tr> <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.name}</td>
<td>${stu.phones}</td> </tr>
</c:forEach>
</table>
</body>
</html>
varstatus类