- EL表達式
EL 全名為Expression Language,就是為了替代<%= %>腳本表達式。
在j2ee1.4以前默認是不支持el,如果需要需要指定page指令[isELIgnored="true | false" ]為false,j2ee4.0后默認支持el
- EL主要作用:
- 1、獲取數據:
EL表達式主要用於替換JSP頁面中的腳本表達式,以從各種類型的web域中檢索java對象、獲取數據。(某個web域 中的對象,訪問javabean的屬性、訪問list集合、訪問map集合、訪問數組)
- 2、執行運算:
利用EL表達式可以在JSP頁面中執行一些基本的關系運算、邏輯運算和算術運算,以在JSP頁面中完成一些簡單的邏輯運算。${user==null}
- 3、獲取web開發常用對象
EL 表達式定義了一些隱式對象,利用這些隱式對象,web開發人員可以很輕松獲得對web常用對象的引用,從而獲得這些對象中的數據。
- 4、調用Java方法
EL表達式允許用戶開發自定義EL函數,以在JSP頁面中通過EL表達式調用Java類的方法。
- 使用EL表達式獲取數據
- 獲取數據(1)
使用EL表達式獲取數據語法:“${標識符}”
EL表達式語句在執行時,會調用pageContext.findAttribute方法,用標識符為關鍵字,分別從page、request、session、application四個域中查找相應的對象,
找到則返回相應對象,找不到則返回”” (注意,不是null,而是空字符串)。
示例:${user}
<%=((HttpServletRequest)pageContext.getRequest()).getContextPath() %> 在獲取后對象后要加括號才能繼續調用對象身上的方法
${pageContext.request.contextPath}
- 獲取數據(2)
EL表達式也可以很輕松獲取JavaBean的屬性,或獲取數組、Collection、Map類型集合的數據,例如:
${strs[1]} //獲取數組中的元素
${user.address.city}
${user.list[0]}:訪問有序集合某個位置的元素
${map.key} : 獲得map集合中指定key的值
結合JSTL的foreach標簽,使用EL表達式也可以很輕松迭代各種類型的數組或集合,示例:
迭代數組
迭代collection類型集合
迭代map類型集合
獲取數據(1)示例:
1 <%@ page language="java" pageEncoding="utf-8"%> 2 <html> 3 <head></head> 4 <body> 5 <% 6 pageContext.setAttribute("name","xxx"); 7 request.setAttribute("name","yyy"); 8 %> 9 此方法從四大作用域中搜尋有沒有對應的屬性,有就獲得,pageContext、request、session、application <br> 10 pageContext.findAttribute("name"): <%= pageContext.findAttribute("name") %> <br> 11 EL:${name } 12 <hr> 13 pageContext.getAttribute("name",pageContext.REQUEST_SCOPE):<%=pageContext.getAttribute("name",pageContext.REQUEST_SCOPE) %><br> 14 EL: ${requestScope.name } 15 <br> 16 <hr> 17 pageContext.getAttribute("age"):<%=pageContext.getAttribute("age") %><br> 18 EL: ${age } 19 </body> 20 </html>
輸出:
pageContext.findAttribute("name"): xxx
EL:xxx
pageContext.getAttribute("name",pageContext.REQUEST_SCOPE):yyy
EL: yyy
pageContext.getAttribute("age"):null
EL:
獲取數據(2)示例:
1 <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> 2 <%@page import="cn.itxushuai.Person"%> 3 <html> 4 <head></head> 5 <body> 6 <hr> 7 獲取javaBean中的屬性<br> 8 <% 9 Person p = new Person(); 10 p.setName("zzzzz"); 11 //p.setAge(10); 12 pageContext.setAttribute("p",p); 13 %> 14 <%=((Person)pageContext.getAttribute("p")).getName() %> 15 <br> 16 ${p.name } 17 <hr> 18 <%= ((HttpServletRequest)pageContext.getRequest()).getContextPath() %> 19 <br> 20 ${pageContext.request.contextPath } 21 22 <hr> 23 獲取數組中的數據 24 <% 25 String [] strs = {"aaa","bb","ccc"}; 26 pageContext.setAttribute("strs",strs); 27 %> 28 <br> 29 <%= strs[1] %> 30 <br> 31 ${strs[1] } 32 33 <hr> 34 從List中獲取數據 35 <% 36 List list = new ArrayList(); 37 list.add("春"); 38 list.add("夏"); 39 list.add("秋"); 40 list.add("冬"); 41 pageContext.setAttribute("season",list); 42 %> 43 <br> 44 <%=((List)pageContext.getAttribute("season")).get(0) %> 45 <br> 46 ${river[0] } 47 <hr> 48 從map中獲取數據 49 <% 50 Map map = new HashMap(); 51 map.put("name","zhang"); 52 map.put("nick.Name","nickZhang"); 53 map.put("age",13); 54 pageContext.setAttribute("map",map); 55 %> 56 <br> 57 <%=((Map)pageContext.getAttribute("map")).get("name") %> 58 <br> 59 ${map.name } 60 ${map["nick.Name"] } 61 </body> 62 </html>
輸出:
獲取javaBean中的屬性
zzzzz
zzzzz
/day08
/day08
獲取數組中的數據
bb
bb
從List中獲取數據
春
從map中獲取數據
zhang
zhang nickZhang
- EL表達式執行運算
(1)算數運算:所有參與元算的元素都會被轉成數字,如果不能轉就報錯,空元素參與運算當作沒參與。
(2)關系運算:
== ---> eq 例如:${5==5}或${5 eq 5}
!= ---> ne
< ---> lt
> ---> gt
<= ---> le
>= ---> ge
(3)邏輯運算:
&& ---> and 例如:${A&&B}或${A and B}
|| ---> or
! ---> not
(4)empty/not empty 判斷一個對象或集合或數組是否為null或長度為0
(5)二元表達式 ${user!= null ? user.name : "";
(6) []和.號運算符
- 使用EL表達式獲得Web開發常用對象
EL表達式語言中定義了11個隱含對象,使用這些隱含對象可以很方便地獲取web開發中的一些常見對象,並讀取這些對象的數據。
語法:${隱式對象名稱} :獲得對象的引用
pageContext:代表pageContext對象,注意和pageScope進行區分
pageScope:代表page域,可以用來獲取page域中的屬性
reqeustScope:代表reqeust域,可以用來獲取reqeust域中的屬性
sessionScope:代表session域,可以用來獲取session域中的屬性
applicationScope:代表application域,可以用來獲取application域中的屬性
param:代表請求參數組成的map集合${param.userName}
paramValues: 代表請求參宿組成的map集合,但是此集合的value是String[],用來獲取一名多值的param
header: 獲取所有HTTP請求字段的map對象
headerValues: 同上,獲取請求頭組成的map,但是value是一個String[]
注意:如果頭里面有“-” ,例Accept-Encoding,則要headerValues[“Accept-Encoding”]
cookie: 獲取cookie組成的map對象,此map的值是一個cookie對象${cookie.cookieName.cookieValue}
initParam: 以map封裝的web.xml中配置的整個web應用的初始化參數
示例:
1 <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> 2 <html> 3 <head></head> 4 <body> 5 <%-- 6 ${pageContext } 7 ${pageScope } 8 ${requestScope } 9 ${sessionScope } 10 ${applicationScope } 11 --%> 12 獲取請求參數 13 ${param.name } <hr> 14 15 獲取請求頭 16 <%= 17 request.getHeader("Host") 18 %> 19 ${header.Host } 20 ${header["Accept-Language"] }<hr> 21 22 el表達式獲取cookie信息<br> 23 <% 24 Cookie cookie = new Cookie("host","localhost"); 25 response.addCookie(cookie); 26 %> 27 28 <% 29 Cookie [] cs = request.getCookies(); 30 if(cs!=null){ 31 for(Cookie c : cs){ 32 if("host".equals(c.getName())){ 33 out.write(c.getValue()); 34 } 35 } 36 } 37 %> <br> 38 cookie.host.value: ${cookie.host.value}<hr> 39 40 整個web應用的初始化參數<br> 41 <%= 42 application.getInitParameter("data1") 43 %><br> 44 initParam: ${initParam.data1 }<hr> 45 46 pageContext.request:${pageContext.request }<br> 47 pageScope.request:${pageScope.request } 48 </body> 49 </html>
輸出
獲取請求參數
獲取請求頭 localhost localhost zh-CN
el表達式獲取cookie信息
localhost
cookie.host.value: localhost
整個web應用的初始化參數
123
initParam: 123
pageContext.request:org.apache.catalina.connector.RequestFacade@99439c
pageScope.request:
- 使用EL調用Java方法
EL表達式語法允許開發人員開發自定義函數,以調用Java類的方法。
示例:${prefix:method(params)}
在EL表達式中調用的只能是Java類的靜態方法。
這個Java類的靜態方法需要在TLD文件中描述,才可以被EL表達式調用。
EL自定義函數用於擴展EL表達式的功能,可以讓EL表達式完成普通Java程序代碼所能完成的功能。
- 開發EL Function步驟:
(1)編寫一個Java類的靜態方法
(2)編寫標簽庫描述符(tld)文件,在tld文件中描述自定義函數。在創建tld文件時應選用2.0版本的jsp配置,指定名稱空間uri和縮寫prefix
在tld文件中配置方法信息
1 <function> 2 <name>encodeURL</name> el在調用時所使用的方法名 3 <function-class>cn.itheima.util.EncodeURL</function-class>靜態方法所在的類全路徑名 4 <function-signature>java.lang.String EncodURL( java.lang.String )//對該方法的描述:返回值類型 方法名(參數類型) 5 </function-signature> 6 </function>
(4)在JSP頁面中導入和使用自定義函數
語法:<%@ taglib uri="" prefix="ppp"%>引入tld文件
(5)在jsp中使用${ppp:encodeURL("xxxx")}調用
- 開發EL Function注意事項
編寫完標簽庫描述文件后,需要將它放置到<web應用>\WEB-INF目錄中或WEB-INF目錄下的除了classes和lib目錄之外的任意子目錄中。
TLD文件中的<uri> 元素用指定該TLD文件的URI,在JSP文件中需要通過這個URI來引入該標簽庫描述文件。
<function>元素用於描述一個EL自定義函數,其中:
<name>子元素用於指定EL自定義函數的名稱。
<function-class>子元素用於指定完整的Java類名,
<function-signature>子元素用於指定Java類中的靜態方法的簽名,方法簽名必須指明方法的返回值類型及各個參數的類型,各個參數之間用逗號分隔。
- EL注意事項
EL表達式是JSP 2.0規范中的一門技術 。因此,若想正確解析EL表達式,需使用支持Servlet2.4/JSP2.0技術的WEB服務器。
注意:有些Tomcat服務器如不能使用EL表達式
(1)升級成tomcat6
(2)在JSP中加入<%@ page isELIgnored="false" %>