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);
}
}
複制
- 定義标簽庫檔案(
标簽庫檔案)并配置标簽說明檔案到到 WEB-INF 目錄下。tld
<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"/>
複制