文章目录
六、EL表达式
1、简介
EL表达式:Expression Language,表达式语言
作用:代替jsp页面中的表达式脚本在jsp页面中进行数据输出
方法: ${ 数据名 }
<%
request.setAttribute("key","value1");
%>
表达式脚本输出:<%=request.getAttribute("key")%>
EL表达式输出:${key}
当四大域对象pageContext、request、session、application中都有相同的key数据时,EL表达式会按照数据域范围从小到大依次查找,找到就输出
2、EL输出Bean对象
<%
Person person = new Person();
person.setAge(12);
person.setName("tom");
person.setPhones(new String[]{"18555773512","15846573215","12462156477"});
person.setCities(Arrays.asList(new String[]{"北京","上海","深圳"}));
Map<String,Object> map = new HashMap<>();
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的String数组phones:${Arrays.toString(p.phones)};<br/>
输出person的String数组phones[1]:${p.phones[1]};<br/>
输出person的List集合cities:${p.cities};<br/>
输出person的List集合cities的第二个元素:${p.cities[1]};<br/>
输出person的Map:${p.map};<br/>
输出person的Map的一个值:${p.map.get("key1")};<br/>
输出person的Map的一个值:${p.map["key2"]};<br/>
输出person的Map的一个值:${p.map.key3};<br/>
注:p.属性调用了Person类的get属性()方法,所以没有破坏封装性
3、EL运算
EL表达式还可以进行关系运算、逻辑运算、算术运算、三元运算符:大于小于等于与或非加减乘除
empty运算: ${ empty objName },以下都返回true
- 值为null
- 值为空串
- 长度为0的数组、list集合、map集合
点运算和中括号运算
-
点运算,可以输出Bean对象中某个属性的值
-
[]中括号运算,可以输出有序集合中某个元素的值,如数组、list中指定索引处的元素;如map中含有特殊字符的key对应的value
- list[ index ]、array[ index ]
- map[ “key” ]
4、11个隐含对象
EL表达式中自己定义了11个隐含对象,可以直接使用
变量 | 类型 | 作用 |
---|---|---|
pageContext | PageContextImpl | 获取jsp中九大内置对象 |
pageScope | Map<String,Object> | 获取pageContext域中数据 |
requestScope | Map<String,Object> | 获取request域中数据 |
sessionScope | Map<String,Object> | 获取session域中数据 |
applicationScope | Map<String,Object> | 获取application域中的数据 |
param | Map<String,String> | 获取请求的参数 |
paramValues | Map<String,String[ ]> | 获取请求的参数,多个值时使用 |
header | Map<String,String> | 获取请求头 |
headerVlues | Map<String,String[ ]> | 获取请求头,多个值时使用 |
cookie | Map<String,Cookie> | 获取当前请求的Cookie信息 |
initParam | Map<String,String> | 获取在web.xml中配置的< context-param > |
演示:
<%
pageContext.setAttribute("key1","pageContextValue1");
%>
${pageScope.key1}
pageContext对象演示:
jsp表达语句<br>
<%=request.getScheme()%><br>
<%=request.getServerName()%><br>
<%=request.getServerPort()%><br>
<%=request.getContextPath()%><br>
<%=request.getMethod()%><br>
<%=request.getRemoteHost()%><br>
<%=request.getRequestedSessionId()%><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.request.session.id}
可以给request设置别名,然后在EL中调用
<%
pageContext.setAttribute("req",request);
%>
1.协议:${req.scheme}<br>
cookie对象演示
${cookie.JSESSIONID}<br>
jakarta.servlet.http.Cookie@36b14f44
${cookie.JSESSIONID.name}<br>
JSESSIONID
${cookie.JSESSIONID.value}<br>
8D442AED625C7C1F9C16B8EEFAD67403
七、JSTL标签库
JSTL标签库:JSP Standard Tag Library,JSP标准标签库,是一个不断完善的开放源代码的jsp标签库
- EL表达式主要是为了替换JSP中的表达式脚本,而JSTL是为了替换代码脚本使得JSP更加简洁
使用步骤
-
导入JSTL标签库的jar包
taglibs-standard-impl-1.2.5.jar、taglibs-standard-spec-1.2.5.jar
注意:Tomcat 10版本下需要使用如下的包才可以运行
jakarta.servlet.jsp.jstl-api-2.0.0.jar、jakarta.servlet.jsp.jstl-2.0.0.jar
-
使用taglib标签引入标签库
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
-
使用JSTL编写代码
core核心库
1、set标签
作用:可以往域中保存键值对数据
格式:<c:set scope=“request” var=“abc” value=“abcValue” />
说明:scope属性——设置保存到哪个域
var属性——设置数据的key
value属性——设置数据的value
保存之前:${requestScope.abc}<br>
<c:set scope="request" var="abc" value="abcValue" />
保存之后:${requestScope.abc}<br>
2、if标签
作用:根据条件判断是否输出
格式:<c:if test=" EL表达式 " > … < /c:if >
说明:test属性——判断的条件(使用EL表达式)
<c:if test="${1>0}">
1>0
</c:if>
3、choose标签
choose、when、otherwise标签,与switch、case、default标签类似
注:when标签的父标签必须是choose标签
<%request.setAttribute("height",(int)(160+Math.random()*40));%>
${requestScope.height}
<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>
4、forEach标签
作用:遍历
格式:< c:forEach var=" " begin=" " end=" "> … < /c:forEach>
说明:var属性——循环的变量(也是当前遍历到的数据)
begin属性——开始的索引
end属性——结束的索引
items属性——遍历的数据源,如数组、list
step属性——遍历的步长值
varStatus属性——当前遍历的数据的状态
练习1:遍历1~10输出
<table border="1">
<c:forEach var="i" begin="1" end="10">
<tr>
<td> ${ i } </td>
</tr>
</c:forEach>
</table>
练习2:遍历String数组
<%
request.setAttribute("arr",new String[]{"18532154762","18761324684","15765132846"});
%>
<c:forEach items="${requestScope.arr}" var="item">
${item}<br>
</c:forEach>
items属性——遍历的数据源,如数组、list
var属性——当前遍历的对象
练习3:遍历Map
<%
Map<String,Object> map = new HashMap<>();
map.put("key1","value1");
map.put("key2","value2");
map.put("key3","value3");
request.setAttribute("map",map);
%>
<c:forEach items="${requestScope.map}" var="item">
${item.key}->${item.value}<br/>
</c:forEach>
练习4:遍历对象数组
public class Student {
private int id;
private String username;
private String password;
private int age;
private String phone;
<%
List<Student> studentList = new ArrayList<>();
for (int i = 1; i <= 10; i++) {
studentList.add(new Student(i,"name"+i,"password"+i,18+i,"phone"+i));
}
request.setAttribute("stus",studentList);
%>
<table border="1" align="center">
<tr>
<th>编号</th>
<th>用户名</th>
<th>密码</th>
<th>年龄</th>
<th>手机号</th>
<th>操作</th>
</tr>
<c:forEach items="${requestScope.stus}" var="stu" varStatus="status">
<tr>
<td>${stu.id}</td>
<td>${stu.username}</td>
<td>${stu.password}</td>
<td>${stu.age}</td>
<td>${stu.phone}</td>
<td>${status.index}</td>
</tr>
</c:forEach>
</table>
结果:
varStatus:可以通过该属性获取当前遍历到的数据的状态
可以通过 ${status.current}、 ${status.index}、 ${status.count}等来调用