天天看點

JavaWeb(四) - EL表達式 和 JSTLEL - (Expression Language)表達式語言JSTL - (JSP Standard Tag Libraries)标準标簽庫

EL - (Expression Language)表達式語言

  • 基本概念

EL 表達式提供了在 JSP 中簡化表達式的方法,可以友善地通路各種資料并輸出。

  • 主要功能

-- 依次通路 pageContext、request、session 和 application 作用域對象存儲的資料。

-- 擷取請求參數值。

-- 通路 Bean 對象的屬性。

-- 通路集合中的資料。

-- 輸出簡單的運算結果。

1. 通路内置對象的資料

<%= request.getAttribute(“varName”) %> 用 EL 實作:${ varName }

2. 通路請求參數的資料

在 EL 之前使用下列方式通路請求參數的資料

request.getParameter(name);
request.getParameterValues(name);
           

在 EL 中使用下列方式通路請求參數的資料

param:接收的參數隻有一個值。

paramValues:接受的參數有多個值。

<!-- 擷取指定參數的數值 -->
${ param.name}
<!-- 擷取指定參數中指定下标的數值 -->
${paramValues.hobby[0]}
           

3. 通路 Bean 對象的屬性

通路方式

方式一: 

${ 對象名.屬性名},例如:${ user.name}

方式二: 

${對象名[“屬性名”]},例如:${user["name"]}

主要差別

當要存取的屬性名中包含一些特殊字元,如: . 或 , 等并非字母或數字的符号,就一定要使用 [] 而不是 . 的方式。

使用 [] 的方式可以動态取值,具體方式如下:

<%
    Person person = new Person();
    person.setName("zhangfei");
    person.setAge(30);
    pageContext.setAttribute("person", person);

    pageContext.setAttribute("var1", "name");
    pageContext.setAttribute("var2", "age");
%>
擷取到的姓名是:${person.name}<br/>
擷取到的年齡是:${person.age}<br/>
擷取到的姓名是:${person["name"]}<br/>
擷取到的年齡是:${person["age"]}<br/>
動态取值的結果為:${person[var1]}
           

4. 通路集合中的資料

<%
    // 準備一個 List 集合并添加資料内容
    List<String> list = new LinkedList<>();
    list.add("two");
    list.add("one");
    list.add("three");
    // 将整個集合放入指定的内置對象中
    pageContext.setAttribute("list", list);

    // 準備一個 Map 集合并添加資料
    Map<String, Integer> map = new HashMap<>();
    map.put("one", 1);
    map.put("two", 2);
    map.put("three", 3);
    // 将整個集合放入指定的内置對象中
    pageContext.setAttribute("map", map);
%>
<%-- 使用 EL 表達式實作集合中資料内容的擷取 --%>
集合中下标為 0 的元素是:${list[0]}<br/>    <%-- two --%>
集合中下标為 1 的元素是:${list[1]}<br/>    <%-- one --%>
集合中下标為 2 的元素是:${list[2]}<br/>    <%-- three --%>
<hr/>
<%-- 使用 EL 表達式實作 Map 集合中資料内容的擷取,不支援下标 --%>
整個 Map 集合中的元素有:${map}<br/>
擷取帶有特殊字元 key 對應的數值為:${map["three"]}<br/>   <%-- 3 --%>
           
  • 常用的内置對象

JSP

pageContext - 處理目前頁面

作用域

pageScope - 同頁面作用域屬性名稱和值有關的 Map 類 ;

requestScope - 同請求作用域屬性的名稱和值有關的 Map 類 ;

sessionScope - 同會話作用域屬性的名稱和值有關的 Map 類;

applicationScope - 同應用程式作用域屬性的名稱和值有關的 Map 類

請求參數

param - 根據名稱存儲請求參數的值的 Map 類

paramValues - 把請求參數的所有值作為一個 String 數組來存儲的 Map 類

請求頭

header - 根據名稱存儲請求頭主要值的 Map 類

headerValues - 把請求頭的所有值作為一個 String 數組來存儲的 Map 類

Cookie

cookie - 根據名稱存儲請求附帶的 cookie 的 Map 類

初始化參數

initParam - 根據名稱存儲 Web 應用程式上下文初始化參數的 Map 類

  • 常用的運算符
<%
    // 通過内置對象設定屬性的方式來準備操作數
    request.setAttribute("ia", 5);
    request.setAttribute("ib", 2);
    request.setAttribute("b1", true);
    request.setAttribute("b2", false);
%>

<%-- 實作上述所有操作數的擷取和列印 --%>
ia 的數值為:${ia}<br/>      <%-- 5 --%>
ib 的數值為:${ib}<br/>      <%-- 2 --%>
b1 的數值為:${b1}<br/>      <%-- true --%>
b2 的數值為:${b2}<br/>      <%-- false --%>
           

算術運算符

<%-- 實作算術運算符的使用 --%>
ia+ib 的結果為:${ia+ib}<br/>    <%-- 7 --%>
ia-ib 的結果為:${ia-ib}<br/>    <%-- 3 --%>
ia*ib 的結果為:${ia*ib}<br/>    <%-- 10 --%>
ia/ib 的結果為:${ia/ib}<br/>    <%-- 2.5 --%>
ia%ib 的結果為:${ia%ib}<br/>    <%-- 1 --%>
           

關系運算符

<%-- 實作關系運算符的使用 --%>
ia 大于 ib 的結果為:${ia > ib}<br/>  <%-- true --%>
ia 大于等于 ib 的結果為:${ia >= ib}<br/>  <%-- true --%>
ia 小于 ib 的結果為:${ia < ib}<br/>  <%-- false --%>
ia 小于等于 ib 的結果為:${ia <= ib}<br/>  <%-- false --%>
ia 等于 ib 的結果為:${ia == ib}<br/>  <%-- false --%>
ia 不等于 ib 的結果為:${ia != ib}<br/>  <%-- true --%>
           

邏輯運算符

<%-- 實作邏輯運算符的使用 --%>
b1 并且 b2 的結果為:${b1 && b2}<br/>  <%-- false --%>
b1 或者 b2 的結果為:${b1 || b2}<br/>  <%-- true --%>
b1 取反的結果為:${ !b1 }<br/>  <%-- false --%>
b2 取反的結果為:${ !b2 }<br/>  <%-- true --%>
           

條件運算符和驗證運算符

Null 值、無元素的集合或數組、長度為零的 String 都被認為是空值。

<%
    String str1 = null;
    String str2 = "";
    String str3 = "hello";

    List<Integer> list1 = new LinkedList<>();
    List<Integer> list2 = Arrays.asList(11, 22, 33, 44, 55);

    request.setAttribute("str1", str1);
    request.setAttribute("str2", str2);
    request.setAttribute("str3", str3);
    request.setAttribute("list1", list1);
    request.setAttribute("list2", list2);
%>
<%-- 實作條件運算符和驗證運算符的使用 --%>
ia 和 ib 之間的最大值為:${ia>ib ? ia : ib}<br/>
判斷是否為空的結果是:${empty str1}<br/>    <%-- true --%>
判斷是否為空的結果是:${empty str2}<br/>    <%-- true --%>
判斷是否為空的結果是:${empty str3}<br/>    <%-- false --%>
判斷是否為空的結果是:${empty list1}<br/>    <%-- true --%>
判斷是否為空的結果是:${empty list2}<br/>    <%-- false --%>
           

JSTL - (JSP Standard Tag Libraries)标準标簽庫

  • 基本概念

JSTL 被稱為 JSP 标準标簽庫。 開發人員可以利用這些标簽取代 JSP 頁面上的 Java 代碼,進而提高程式的可讀性,降低程式的維護難度。

  • 如何使用

下載下傳 JSTL 的 jar 包并添加到項目中,下載下傳位址為:https://tomcat.apache.org/download-taglibs.cgi

在JSP頁面中使用 

taglib

 指定引入 JSTL 标簽庫:

<!-- prefix 屬性用于指定庫字首 -->
<!-- uri 屬性用于指定庫的辨別 -->
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
           
  • 核心标簽
  • 常用核心标簽

輸出标簽

用來将指定内容輸出的标簽

<c:out value="Hello World"></c:out>
           

設定标簽

用來設定屬性範圍值的标簽

<%-- pageContext.setAttibute("name", "zhangfei") --%>
<c:set var="name" value="zhangfei" scope="page"></c:set>
<c:out value="${name}"></c:out>

<%-- 設定一個對象的屬性值并列印出來 --%>
<jsp:useBean id="person" class="com.renda.Person" scope="page"></jsp:useBean>
<c:set property="name" value="guanyu" target="${person}"></c:set>
<c:set property="age" value="35" target="${person}"></c:set>
<c:out value="${person.name}"></c:out>
<c:out value="${person.age}"></c:out>
           

删除标簽

用來删除指定資料的标簽

<c:remove var="name" scope="page"></c:remove>
<c:out value="${name}" default="無"></c:out>
           

單條件判斷标簽

<c:set var="age" value="17" scope="page"></c:set>
<c:out value="${age}"></c:out>
<c:if test="${age >= 18}">
    <c:out value="已經成年"></c:out>
</c:if>
           

多條件判斷标簽

<c:set var="score" value="59" scope="page"></c:set>
<c:out value="${score}"></c:out>
<c:choose>
    <c:when test="${score > 60}">
        <c:out value="成績合格"></c:out>
    </c:when>
    <c:when test="${score == 60}">
        <c:out value="剛好合格"></c:out>
    </c:when>
    <c:otherwise>
        <c:out value="成績不合格"></c:out>
    </c:otherwise>
</c:choose>
           

循環标簽

<%
    // 準備一個數組并初始化
    String[] sArr = {"11", "22", "33", "44", "55"};
    pageContext.setAttribute("sArr", sArr);
%>
<%-- 使用循環标簽周遊數組中的所有元素 --%>
<c:forEach var="ts" items="${sArr}">
    <c:out value="${ts}"></c:out>
</c:forEach>
<%-- 跳躍性周遊。間隔為 2 --%>
<c:forEach var="ts" items="${sArr}" step="2">
    <c:out value="${ts}"></c:out>
</c:forEach>
<%-- 指定起始和結尾位置。包含 1 和 3 --%>
<c:forEach var="ts" items="${sArr}" begin="1" end="3">
    <c:out value="${ts}"></c:out>
</c:forEach>
           

函數标簽

常用函數标簽

<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
<%
    pageContext.setAttribute("var", "HelloWorld");
%>
原始字元串為:${var}<br/>    <%-- HelloWorld --%>
判斷該字元串是否包含指定字元串的結果為:${fn:contains(var, "Hello")}<br/>  <%-- true --%>
将字元串中所有字元轉換為大寫的結果為:${fn:toUpperCase(var)}<br/>          <%-- HELLOWORLD--%>
将字元串中所有字元轉換為小寫的結果為:${fn:toLowerCase(var)}<br/>  <%-- helloworld --%>
           

格式化标簽

常用格式化标簽

<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%
    // 擷取目前系統時間
    Date date = new Date();
    pageContext.setAttribute("date", date);
%>
目前系統時間為:${date}
格式化後的時間:<fmt:formatDate value="${date}" pattern="yyyy-MM-dd HH:mm:ss"></fmt:format
           

自定義标簽

如果上面幾個标簽不能滿足需求,程式員也可以自定義标簽。步驟如下。

  • 編寫标簽類繼承 SimpleTagSupport 類或 TagSupport 類并重寫 doTag 方法或 doStartTag 方法。
public class HelloTag extends SimpleTagSupport {
    private String name;
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public void doTag() throws JspException, IOException {
        JspWriter out = this.getJspContext().getOut();
        out.println("自定義标簽的參數為:" + name);
    }
}
           
  • 定義标簽庫檔案(tld 标簽庫檔案)并配置标簽說明檔案到到 WEB-INF 目錄下。
<taglib xmlns="http://java.sun.com/xml/ns/javaee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd"
        version="2.1">

    <tlib-version>1.0</tlib-version>
    <short-name>my</short-name>
    <uri>http://renda.com</uri>

    <!-- Invoke 'Generate' action to add tags or functions -->
    <tag>
        <name>hello</name>
        <tag-class>com.renda.HelloTag</tag-class>
        <body-content>empty</body-content>
        <attribute>
            <name>name</name>
            <required>true</required>
        </attribute>
    </tag>
</taglib>
           
  • 在 JSP 中添加 taglib 指令引入标簽庫使用:
<%@ taglib prefix="my" uri="http://renda.com" %>
<my:hello name="David"/>