天天看點

JavaWeb - EL and JSTL

EL - Expression Language

Basic Concept

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

Main Function

依次通路

pageContext

request

session

application

作用域對象存儲的資料。

擷取請求參數值。

通路 Bean 對象的屬性。

通路集合中的資料。

輸出簡單的運算結果。

通路内置對象的資料

<%= request.getAttribute(“varName”) %>

用 EL 實作:

${ varName }

通路請求參數的資料

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

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

複制

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

param

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

paramValues

:接受的參數有多個值。

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

複制

通路 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]}           

複制

通路集合中的資料

<%
    // 準備一個 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("th.ree", 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["th.ree"]}<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

Basic Concept

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

How to Use JSTL

下載下傳 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" %>           

複制

Core Tags

常用核心标簽

輸出标簽

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

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

複制

Function Tags

常用函數标簽

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

複制

Formatting Tags

常用格式化标簽

<%@ 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:formatDate>           

複制

JSP Custom Tags

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

  • 編寫标簽類繼承

    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"/>           

複制