EL 表达式 & JSTL 标签库

1.EL 表达式

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

    <body> 
    <% 
    request.setAttribute("key","值"); 
    %>
    表达式脚本输出 key 的值是: 
    <%=request.getAttribute("key1")==null?"":request.getAttribute("key1")%><br/> 
    EL 表达式输出 key 的值是:${key1} 
    </body> 
    

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

  • EL 表达式搜索域数据的顺序
    EL 表达式主要是在 jsp 页面中输出数据。
    作用域:
    request: 一次请求
    session:一次回话(浏览器打开-关闭)
    application:整个应用程序(程序结束)
    pageContext: 一个页面

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

    <body> 
    <% 
    //往四个域中都保存了相同的 key 的数据。 
    request.setAttribute("key", "request");
    session.setAttribute("key", "session"); 
    application.setAttribute("key", "application"); 
    pageContext.setAttribute("key", "pageContext"); 
    %>
    ${ key } 
    </body> 
    
  1. EL 表达式输出 Bean(对象) 的普通属性,数组属性。List 集 合属性,map 集合属性
    注意:
    1)对象获取必须有get/set (getXXXX)
    2)获取对象的属性必须是get后面的字符串
    i.
    需求——输出 Person 类中普通属性,数组属性。list 集合属性和 map 集合属性。
    Person 类

    public class Person { 
    // 
    

    i.需求——输出 Person 类中普通属性,数组属性。list 集合属性和 map 集合属性。

    private String name; 
    private String[] phones; 
    private List<String> cities; 
    private Map<String,Object> map; 
    public int getAge() { 
    return 18; 
    } 
    

    输出的代码:

    <body> 
    <% 
    Person person = new Person(); 
    person.setName("哎哎哎"); 
    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> 
    输出 Person 的 age 属性:${p.age} <br> 
    </body> 
    
  2. EL 表达式——运算
    语法:${ 运算表达式 } , EL 表达式支持如下运算符:
    (1) 关系运算

    	关系运算符	说 明		范 例							结果
    	== 或 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
    

    (2)逻辑运算
    逻辑运算符 说 明 范 例 结果
    && 或 and 与运算 55 && 4>5
    或5
    5 and 4>5 False
    || 或 or 或运算 5 || 4>5
    或5
    5 || 4>5 true
    ! 或 not 取反运算 !(55)
    或not (5
    5) false

    (3)算数运算

    • 关系运算符 说 明 范 例 结果
      +加法 ${ 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。
      以下几种情况为空:
      1、值为 null 值的时候,为空
      2、值为空串的时候,为空
      3、值是 Object 类型数组,长度为零的时候
      4、list 集合,元素个数为零
      5、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/> 
      ${ empty emptyStr } <br/> 
      ${ empty emptyArr } <br/> 
      ${ empty emptyList } <br/> 
      ${ empty emptyMap } <br/> 
      </body> 
      
    • 三元运算
      表达式 1?表达式 2:表达式 3
      如果表达式 1 的值为真,返回表达式 2 的值,如果表达式 1 的值为假,返回表达式 3 的值。示例:
      ${ 12 != 12 ? “111”:“2222” }

    • “.”点运算 和 [] 中括号运算符
      .点运算,可以输出 Bean 对象中某个属性的值。
      []中括号运算,可以输出有序集合中某个元素的值。
      并且[]中括号运算,还可以输出 map 集合中 key 里含有特殊字符的 key 的值。

      <body> 
      <% 
      Map<String,Object> map = new HashMap<String, Object>(); 
      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> 
      
  3. EL 表达式的 11 个隐含对象

    变量			 类型				作用
    pageContext		 PageContextImpl		它可以获取 jsp 中的九大内置对象
    pageScope	 	 Map<String,Object>	它可以获取 pageContext 域中的数据
    requestScope	 Map<String,Object>	它可以获取 Request 域中的数据
    sessionScope	 Map<String,Object>	它可以获取 Session 域中的数据
    applicationScope Map<String,Object>	它可以获取 ServletContext 域中的数据
    param			 Map<String,String>	它可以获取请求参数的值
    paramValues		 Map<String,String[]>它也可以获取请求参数的值,获取多个值的时候使用。
    header			 Map<String,String>	它可以获取请求头的信息
    headerValues	 Map<String,String[]>它可以获取请求头的信息,它可以获取多个值的情况
    cookie			 Map<String,Cookie>	它可以获取当前请求的 Cookie 信息
    initParam		 Map<String,String>	它可以获取在web.xml中配置的<context-param>上下文参数
    
  • EL 获取四个特定域中的属性
    对象 说明
    pageScope pageContext 域
    requestScope Request 域
    sessionScope Session 域
    applicationScope ServletContext 域

    <body> 
    <% 
    pageContext.setAttribute("key1", "pageContext1"); 
    pageContext.setAttribute("key2", "pageContext2"); 
    request.setAttribute("key2", "request"); 
    session.setAttribute("key2", "session"); 
    application.setAttribute("key2", "application"); 
    %>
    ${ applicationScope.key2 } 
    </body> 
    
  • pageContext 对象的使用
    1. 协议:
    2. 服务器 ip:
    3. 服务器端口:
    4. 获取工程路径:
    5. 获取请求方法:
    6. 获取客户端 ip 地址:
    7. 获取会话的 id 编号:

    <body> 
    <%-- 
    request.getScheme() 它可以获取请求的协议 
    request.getServerName() 获取请求的服务器 ip 或域名 
    request.getServerPort() 获取请求的服务器端口号 
    getContextPath() 获取当前工程路径 
    request.getMethod() 获取请求的方式(GET 或 POST) 
    request.getRemoteHost() 获取客户端的 ip 地址 
    session.getId() 获取会话的唯一标识 
    --%> 
    <% 
    pageContext.setAttribute("req", request);  //不可以直接使用requestScope
    %>
    <%=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 表达式其他隐含对象的使用
    param Map<String,String> 它可以获取请求参数的值
    paramValues Map<String,String[]> 它也可以获取请求参数的值,获取多个值的时候使用。
    示例代码:

    输出请求参数 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/srr/vv.jsp?username=wzg168&password=666666&hobby=java&hobby=cpp
    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 中配置的<context-param>上下文参数 
    

    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" %> 
  • JSTL 标签库的使用步骤
    1、先导入 jstl 标签库的 jar 包。
    taglibs-standard-impl-1.2.1.jar
    taglibs-standard-spec-1.2.1.jar
    2、第二步,使用 taglib 指令引入标签库。

    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> 
    
  • core 核心库使用

    1. <c:set />(使用很少)
      作用:set 标签可以往域中保存数据

      <%-- 
      <c:set /> 
      作用:set 标签可以往域中保存数据 
      域对象.setAttribute(key,value); 
      scope 属性设置保存到哪个域 
      page 表示 PageContext 域(默认值) 
      request 表示 Request 域 
      session 表示 Session 域 
      application 表示 ServletContext 域 
      var 属性设置 key 是多少 
      value 属性设置值 
      --%> 
      

      保存之前:$ { sessionScope.abc }

      <c:set scope=“session” var=“abc” value=“abcValue”/>
      保存之后:$ { sessionScope.abc }

      1. <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> 
    
  1. <c:choose> <c:when> <c:otherwise>标签
    作用:多路判断。跟 switch … case … default 非常接近

    <%-- 
    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> 
    <%-- 这是 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> 
    
  2. <c:forEach />
    作用:遍历输出使用。

    遍历 1 到 10,输出
    示例代码:

    <%--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> 
    

    遍历 Object 数组
    示例代码:

    <%-- 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>
    

    遍历 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 { 
    //4.编号,用户名,密码,年龄,电话信息 
    private Integer id; 
    private String username; 
    private String password; 
    private Integer age; 
    private String phone; 
    

    示例代码:

    <%--4.遍历 List 集合---list 中存放 Student 类,有属性:编号,用户名,密码,年龄,电话信息--%> 
    <% 
    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> 
    <%--
    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>
    
    <%@page import="com.ssw.bean.Student"%>
    <%@page import="java.util.ArrayList"%>
    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html>
    <html>
    	<head>
    	<meta charset="UTF-8">
    		<title>Insert title here</title>
    	</head>
    <body>
    <%
    	ArrayList<Student> list = new ArrayList<Student>();
    	Student stu1 = new Student("刘阳","222","333");
    	Student stu2 = new Student("444","555","666");
    	list.add(stu1);
    	list.add(stu2);
    	list.add(stu1);
    	list.add(stu2);
    	list.add(stu1);
    	list.add(stu2);
    	list.add(stu1);
    	list.add(stu2);
    	list.add(stu1);
    	list.add(stu2);
    	request.setAttribute("list", list);
    %>
    <c:set scope="session" var="username" value="赵四"></c:set>
    <c:set scope="session" var="lists" value="${list}"></c:set>
    <%-- ${username}<br> ${lists} --%>
    <table>
    	<tr>
    		<th>行号</th>
    		<th>用户名</th>
    		<th>密码</th>
    		<th>性别</th>
    	</tr>
    <!--  		 开始下表  结束下表   步长    集合             每一个元素      状态(序号)--> 
     <c:forEach begin="0" end="100" step="1" items="${lists}" var="stu" varStatus="status">
    <!-- jstl c:if  没有else 的标签 -->
    	<c:if test="${ (status.index+1) mod 2 eq 0}">
    		<tr style="background-color: skyblue">
    	</c:if>
    	<c:if test="${ (status.index+1) mod 2 ne 0}">
    		<tr style="background-color: pink">
    	</c:if>
    	<td>${status.index+1}</td>
    	<c:choose>
    		<c:when test="${(status.index+1) mod 3 eq 0 }">
    			<td style="color:red">
    		</c:when>
    		<c:when test="${(status.index+1) mod 5 eq 0 }">
    			<td style="color:blue">
    		</c:when>
    	<c:otherwise>
    	<c:choose>
    <c:when test="${(status.index+1) mod 7 eq 0 }">
    	<td style="color:green">
    </c:when>
    <c:otherwise>
    	<td>
    </c:otherwise>
    </c:choose>
    </c:otherwise>
    </c:choose>
    	${stu.username}</td>
    	<td>${stu.password}</td>
    	<td>${stu.sex}</td>
    </tr>
    </c:forEach>
    </table>
    </body>
    </html>
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值