首页 > 代码库 > EL表达式
EL表达式
EL表达式简介
EL 全名为Expression Language。
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表达式获取数据语法:“${标识符}”
EL表达式语句在执行时,会调用pageContext.findAttribute方法,用标识符为关键字,分别从page、request、session、application四个域中查找相应的对象,找到则返回相应对象,找不到则返回”” (注意,不是null,而是空字符串)
示例:
//1,取字符串 <% String data = "abcd"; request.setAttribute("data",data); %> ${data} // abcd //2,获取域中存的javabean的数据 <% Person p = new Person(); p.setName("aaaa"); request.setAttribute("person",p); %> ${person.name } //aaaa //3,获取域中存的javabean中的javabean的数据 <% Person p1 = new Person(); Address a = new Address(); a.setCity("上海"); p1.setAddress(a); request.setAttribute("p1",p1); %> ${p1.address.city } //上海 //4,获取域中存的list集合中的数据 <% List list = new ArrayList(); list.add(new Person("aaa")); list.add(new Person("bbb")); request.setAttribute("list",list); %> ${list[1].name } //bbb //5,获取域中map集合中的数据 <% Map map = new HashMap(); map.put("aa",new Person("aaaaa")); map.put("bb",new Person("bbbbb")); map.put("cc",new Person("ccccc")); map.put("dd",new Person("ddddd")); map.put("111",new Person("eeeee")); request.setAttribute("map111",map); %> ${map111.bb.name } //bbbbb ${map111[‘111‘].name } //eeeee
二,执行运算:
语法:${运算表达式},EL表达式支持如下运算符:
还有 empty运算符:检查对象是否为null或“空”
二元表达式:${user!=null?user.name : “”} ,(数据回显)
[ ] 和 . 号运算符
<% request.setAttribute("gender","male"); %> <input type="radio" name="gender" value="http://www.mamicode.com/male" ${gender==‘male‘?‘checked‘:‘‘ }>男 <input type="radio" name="gender" value="http://www.mamicode.com/female" ${gender==‘female‘?‘checked‘:‘‘ }>女
三,获取web开发常用对象:
EL表达式语言中定义了11个隐含对象,使用这些隐含对象可以很方便地获取web开发中的一些常见对象,并读取这些对象的数据。
语法:${隐式对象名称} :获得对象的引用
隐含对象名称 |
描 述 |
pageContext |
对应于JSP页面中的pageContext对象(注意:取的是pageContext对象。) |
pageScope |
代表page域中用于保存属性的Map对象 |
requestScope |
代表request域中用于保存属性的Map对象 |
sessionScope |
代表session域中用于保存属性的Map对象 |
applicationScope |
代表application域中用于保存属性的Map对象 |
param |
表示一个保存了所有请求参数的Map对象 |
paramValues |
表示一个保存了所有请求参数的Map对象,它对于某个请求参数,返回的是一个string[] |
header |
表示一个保存了所有http请求头字段的Map对象 |
headerValues |
同上,返回string[]数组。注意:如果头里面有“-” ,例Accept-Encoding,则要headerValues[“Accept-Encoding”] |
cookie |
表示一个保存了所有cookie的Map对象 |
initParam |
表示一个保存了所有web应用初始化参数的map对象 |
注意事项:
测试headerValues时,如果头里面有“-” ,例Accept-Encoding,则要headerValues[“Accept-Encoding”]
测试cookie时,例${cookie.key}取的是cookie对象,如访问cookie的名称和值,须${cookie.key.name}或${cookie.key.value}
四,调用Java方法:
EL表达式语法允许开发人员开发自定义函数,以调用Java类的方法。
示例:${prefix:method(params)}
1,在EL表达式中调用的只能是Java类的静态方法。
2,这个Java类的静态方法需要在TLD文件中描述,才可以被EL表达式调用。
EL自定义函数用于扩展EL表达式的功能,可以让EL表达式完成普通Java程序代码所能完成的功能
步骤:
1,编写一个Java类的静态方法
2,编写标签库描述符(tld)文件,在tld文件中描述自定义函数
3,在JSP页面中导入和使用自定义函数
代码:
public class ElUtils { public static String filter(String message){ if (message == null) return (null); char content[] = new char[message.length()]; message.getChars(0, message.length(), content, 0); StringBuffer result = new StringBuffer(content.length + 50); for (int i = 0; i < content.length; i++) { switch (content[i]) { case ‘<‘: result.append("<"); break; case ‘>‘: result.append(">"); break; case ‘&‘: result.append("&"); break; case ‘"‘: result.append("""); break; default: result.append(content[i]); } } return (result.toString()); } public static Map a(List list,int age){ System.out.println("hahha"); return null; } public static String join(String a,String b){ return a+b; } }
tld描述文件:
<?xml version="1.0" encoding="UTF-8" ?> <taglib xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd" version="2.0"> <description> A tag library exercising SimpleTag handlers. </description> <tlib-version>1.0</tlib-version> <short-name>SimpleTagLibrary</short-name> <uri>/myel</uri> <function> <name>filter</name>//子元素用于指定EL自定义函数的名称 <function-class>cn.yujian.web.el.ElUtils</function-class>//子元素用于指定完整的Java类名, <function-signature> java.lang.String filter( java.lang.String ) </function-signature>//子元素用于指定Java类中的静态方法的签名,方法签名必须指明方法的返回值类型及各个参数的类型,各个参数之间用逗号分隔。 </function> <function> <name>a</name> <function-class>cn.yujian.web.el.ElUtils</function-class> <function-signature> java.util.Map a(java.util.List,int) </function-signature> </function> <function> <name>join</name> <function-class>cn.yujian.web.el.ElUtils</function-class> <function-signature> java.lang.String join( java.lang.String,java.lang.String ) </function-signature> </function> </taglib>
jsp中是使用:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@page import="cn.yujian.domain.User"%> <%@taglib uri="/myel" prefix="myel" %> //声明uri <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>el函数</title> </head> <body> ${myel:filter(‘<a href="">点点</a>‘)} <% List list = new ArrayList(); request.setAttribute("list",list); %> ${myel:a(list,12) } <% User user = new User(); user.setUsername("aaa"); //session.setAttribute("user",user); %> ${user!=null?myel:join(‘欢迎您:‘,user.username):‘‘ } </body> </html>
l编写完标签库描述文件后,需要将它放置到<web应用>\WEB-INF目录中或WEB-INF目录下的除了classes和lib目录之外的任意子目录中。
lTLD文件中的<uri> 元素用指定该TLD文件的URI,在JSP文件中需要通过这个URI来引入该标签库描述文件。
EL表达式