(10)可还记得那被遗忘的EL表达式和JSTL标签库

1,EL表达式

2,JSTL 标签库

EL表达式

1,什么是 EL 表达式,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 字符串。

2,EL 表达式搜索域数据的顺序

  • EL 表达式主要是在 jsp 页面中输出数据。

  • 主要是输出域对象中的数据。

  • 当四个域中都有相同的 key 的数据的时候,EL 表达式会按照四个域的从小到大的顺序去进行搜索,找到就输出。

  • 使用案例:

  <body>
  <%
    // 往四个域中都保存了相同的 key 的数据。
    request.setAttribute("key", "request");
    session.setAttribute("key", "session");
    application.setAttribute("key", "application");
    pageContext.setAttribute("key", "pageContext");
  %>
  ${ key } <!-- pageContext -->
  </body>

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

  • 输出 Person 类中普通属性,数组属性。list 集合属性和 map 集合属性的案例:

    • Person 类:
	public class Person {
		private String name;
		private String[] phones;
		private List<String> cities;
		private Map<String,Object> map;
	}
  • 输出的代码:
<body>
    <%
      Person person = new Person();
      person.setName("Tommey周");
      person.setPhones(new String[]{"18610541354","18688886666","18699998888"});
      List<String> cities = new ArrayList<String>();
      cities.add(" 杭州");
      cities.add(" 上海");
      cities.add(" 深圳");
      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("p", person);
    %>
    输出 Person:${ p }<br/>
    输出 Person 的 name 属性:${p.name} <br>
    输出 Person 的 pnones 数组属性值:${p.phones[2]} <br>
    输出 Person 的 cities 集合中的元素值:${p.cities} <br>
    输出 Person 的 List 集合中个别元素值:${p.cities[2]} <br>
    输出 Person 的 Map 集合: ${p.map} <br>
    输出 Person 的 Map 集合中某个 key 的值: ${p.map.key3} <br>
  </body>

4,EL 表达式 —— 运算

  • 语法:${ 运算表达式 } , EL 表达式支持如下运算符:

①,关系运算

关系运算符说 明范 例结果
== 或 eq等于${ 5 == 5 } 或 ${ 5 eq 5 }true
!= 或 ne不等于${ 5 !=5 } 或 ${ 5 ne 5 }false
< 或 lt小于${ 3 < 5 } 或 ${ 3 lt 5 }true
> 或 gt大于${ 2 > 10 } 或 ${ 2 gt 10 }false
<= 或 le小于等于${ 5 <= 12 } 或 ${ 5 le 12 }true
>= 或 ge大于等于${ 3 >= 5 } 或 ${ 3 ge 5 }false

②,逻辑运算

逻辑运算符说 明范 例结果
&& 或 and与运算${ 12 == 12 && 12 < 11 } 或 ${ 12 == 12 and 12 < 11 }false
|| 或 or或运算${ 12 == 12 || 12 < 11 } 或 ${ 12 == 12 or 12 < 11}true
! 或 not取反运算${ !true } 或 ${not true }false

③,算数运算

算数运算符说 明范 例结果
+加法${ 12 + 18 }30
-减法${ 18 - 8 }10
*乘法${ 12 * 12 }144
/ 或 div除法${ 144 / 12 } 或 ${ 144 div 12 }12
% 或 mod取模${ 144 % 10 } 或 ${ 144 mod 10 }4

④,empty 运算

  • empty 运算可以判断一个数据是否为空,如果为空,则输出 true,不为空输出 false。

  • 以下几种情况为空:

    值为 null 值的时候,为空

    值为空串的时候,为空

    值是 Object 类型数组,长度为零的时候

    list 集合,元素个数为零

    map 集合,元素个数为零

  • 使用案例:

  <body>
    <%
      // 1 、值为 null 值的时候,为空
      request.setAttribute("emptyNull", null);
      // 2 、值为空串的时候,为空
      request.setAttribute("emptyStr", "");
      // 3 、值是 Object 类型数组,长度为零的时候
      request.setAttribute("emptyArr", new Object[]{});
      // 4 、 list 集合,元素个数为零
      List<String> list = new ArrayList<>();
      // list.add("abc");
      request.setAttribute("emptyList", list);
      // 5 、 map 集合,元素个数为零
      Map<String,Object> map = new HashMap<String, Object>();
      // map.put("key1", "value1");
      request.setAttribute("emptyMap", map);
    %>
    ${ empty emptyNull } <br/><!-- true -->
    ${ empty emptyStr } <br/> <!-- true -->
    ${ empty emptyArr } <br/> <!-- true -->
    ${ empty emptyList } <br/><!-- true -->
    ${ empty emptyMap } <br/> <!-- true -->
  </body>

⑤,三元运算

  • 表达式 1?表达式 2:表达式 3

  • 如果表达式 1 的值为真,返回表达式 2 的值,如果表达式 1 的值为假,返回表达式 3 的值。

⑥,"."点运算和 [] 中括号运算符

  • .点运算,可以输出 Bean 对象中某个属性的值。

  • []中括号运算,可以输出有序集合中某个元素的值,并且[]中括号运算,还可以输出 map 集合中 key 里含有特殊字符的 key 的值。

  • 使用案例:

 <body>
  <%
    Map<String,Object> 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>
  </body>

5,EL 表达式的 11 个隐含对象

  • EL 个达式中 11 个隐含对象,是 EL 表达式中自己定义的,可以直接使用。
变量类型作用
pageContextPageContextImpl它可以获取 jsp 中的九大内置对象
pageScopeMap<String,Object>它可以获取 pageContext 域中的数据
requestScopeMap<String,Object>它可以获取 Request 域中的数据
sessionScopeMap<String,Object>它可以获取 Session 域中的数据
applicationScopeMap<String,Object>它可以获取 ServletContext 域中的数据
paramMap<String,String>它可以获取请求参数的值
paramValuesMap<String,String[]>它也可以获取请求参数的值,获取多个值的时候使用。
headerMap<String,String>它可以获取请求头的信息
headerValuesMap<String,String[]>它可以获取请求头的信息,它可以获取多个值的情况
cookieMap<String,Cookie>它可以获取当前请求的 Cookie 信息
initParamMap<String,String>它可以获取在 web.xml 中配置的上下文参数

①,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 }
  </body>

②,pageContext 对象的使用

协议:
服务器 ip:
服务器端口:
获取工程路径:
获取请求方法:
获取客户端 ip 地址:
获取会话的 id 编号:

  • 使用案例:
  <body>
  <%--
  request.getScheme() 它可以获取请求的协议
  request.getServerName() 获取请求的服务器 ip 或域名
  request.getServerPort() 获取请求的服务器端口号
  getContextPath() 获取当前工程路径
  request.getMethod() 获取请求的方式( GETPOST )
  request.getRemoteHost() 获取客户端的 ip 地址
  session.getId() 获取会话的唯一标识
  --%>
  <%
    pageContext.setAttribute("req", request);
  %>
  <%=request.getScheme() %> <br>
  1.协议: ${ 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>
  </body>

③,EL 表达式其它隐含对象的使用

变量类型作用
paramMap<String,String>它可以获取请求参数的值
paramValuesMap<String,String[]>它也可以获取请求参数的值,获取多个值的时候使用
headerMap<String,String>它可以获取请求头的信息
headerValuesMap<String,String[]>它可以获取请求头的信息,它可以获取多个值的情况
cookieMap<String,Cookie>它可以获取当前请求的 Cookie 信息
initParamMap<String,String>它可以获取在 web.xml 中配置的<context-param>上下文参数

示例代码:

  <body>
  输出请求参数 username 的值:${ param.username } <br>
  输出请求参数 password 的值:${ param.password } <br>
  输出请求参数 username 的值:${ paramValues.username[0] } <br>
  输出请求参数 hobby 的值:${ paramValues.hobby[0] } <br>
  输出请求参数 hobby 的值:${ paramValues.hobby[1] } <br>
  </body>
  • 访问地址
http://localhost:8080/ServletTest/index.jsp?username=Tommey%E5%91%A8&password=666666&hobby=java&hobby=cpp 
  <body>
  输出请求头【User-Agent】的值:${ header['User-Agent'] } <br>
  输出请求头【Connection】的值:${ header.Connection } <br>
  输出请求头【User-Agent】的值:${ headerValues['User-Agent'][0] } <br>
  获取 Cookie 的名称:${ cookie.JSESSIONID.name } <br>
  获取 Cookie 的值:${ cookie.JSESSIONID.value } <br>
  输出&lt;Context-param&gt;username 的值:${ initParam.username } <br>
  输出&lt;Context-param&gt;url 的值:${ initParam.url } <br>
  </body>
JSTL 标签库
  • JSTL 标签库 全称是指 JSP Standard Tag Library JSP 标准标签库。是一个不断完善的开放源代码的 JSP 标签库。

  • EL 表达式主要是为了替换 jsp 中的表达式脚本,而标签库则是为了替换代码脚本。这样使得整个 jsp 页面变得更佳简洁。

  • JSTL 由五个不同功能的标签库组成。

功能范围URI前缀
核心标签库-- 重点http://java.sun.com/jsp/jstl/corec
格式化http://java.sun.com/jsp/jstl/fmtfmt
函数http://java.sun.com/jsp/jstl/functionsfn
数据库(不使用)http://java.sun.com/jsp/jstl/sqlsql
XML(不使用)http://java.sun.com/jsp/jstl/xmlx
  • 在 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" %>

1,JSTL 标签库的使用步骤

①、先导入 jstl 标签库的 jar 包。

taglibs-standard-impl-1.2.1.jar 包的下载

taglibs-standard-spec-1.2.1.jar 包的下载

②、第二步,使用 taglib 指令引入标签库。

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

2,core 核心库使用

①,<c:set /> (使用很少)

  • 作用:set 标签可以往域中保存数据

  • 示例代码:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<html>
  <head>
    <title>Title</title>
  </head>
  <body>
  <%--
  i.<c:set />
  作用: 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>
  </body>
</html>

②, <c:if />

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

③, <c:choose> <c:when> <c:otherwise>

  • 作用:多路判断。跟 switch … case … default 非常接近
  <body>
  <%--
  iii.<c:choose> <c:when> <c:otherwise> 标签
  作用:多路判断。跟 switch ... case .... default 非常接近
  choose 标签开始选择判断
  when 标签表示每一种判断情况
  test 属性表示当前这种判断情况的值
  otherwise 标签表示剩下的情况
  <c:choose> <c:when> <c:otherwise> 标签使用时需要注意的点:
  1 、标签里不能使用 html 注释,要使用 jsp 注释
  2 、 when 标签的父标签一定要是 choose 标签
  --%>
  <%
    request.setAttribute("height", 180);
  %>
  <c:choose>
    <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:otherwise>
          其他小于等于 160
        </c:otherwise>
      </c:choose>
    </c:otherwise>
  </c:choose>
 </body>

④, <c:forEach />

  • 作用:遍历输出使用。

  • 遍历 1 到 10,示例代码:

<%-- 遍历 110 ,输出
  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>
  • 遍历 Object 数组,示例代码:
<%--  遍历 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>
  • 遍历 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 放 中存放 Student 类 , 有属性 : 编号 , 用户名 , 密码 , 年龄 ,电话信息,示例代码:

  • Student 类

	public class Student {
		private Integer id;
		private String username;
		private String password;
		private Integer age;
		private String phone;
	}
<body>
  <%
    List<Student> studentList = new ArrayList<Student>();
    for (int i = 1; i <= 10; i++) {
      studentList.add(new Student(i,"Tommey周"+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>
  </body>

下一章,(11)JavaWeb中常用的文件上传和下载

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值