这节我们总结一下EL表达式相关内容。
1. EL表达式主要作用
EL表达式说白了,就是让JSP写起来更加方便,它属于JSP技术。那么它主要都有哪些方面的作用呢?
1.1 获取数据
EL表达式可以用于替换JSP页面中的脚本表达式,以从各种类型的web域中检索对象、获取数据(某个web域中的对象,访问javabean的属性、访问list,map集合、访问数组)。在JSP页面中可使用${标识符}的形式,通知JSP引擎调用pageContext.findAttribute()方法,以标识符为关键字从各个域对象中获取对象。如果对象中不存在标识符所对应的对象,则返回""(注意不是null)。下面是EL表达式获取数据的几种情况,由于JSP是用来获取servlet传递过来的数据,所以在这个JSP里面先模拟向域中存放数据,再获取。具体看下面的例子:
<%@page import="javaBean.Address"%> <%@page import="javaBean.Person"%> <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>EL表达式 <% request.setAttribute("name", "aaa"); //先向request域中存个对象 %> ${name } <% Person p = new Person(); p.setAge(12); request.setAttribute("person", p); %> ${person.age} <% Person person = new Person(); Address address = new Address(); person.setAddress(address); request.setAttribute("person", person); %> ${person.address.name} <% Person p1 = new Person(); p1.setName("aa"); Person p2 = new Person(); p2.setName("bb"); Listlist = new ArrayList (); list.add(p1); list.add(p2); request.setAttribute("list", list); %> ${list[0].name} <% Map map = new HashMap (); map.put("a", "aaaax"); map.put("b", "bbbbx"); map.put("1", "ccccx"); request.setAttribute("map", map); %> ${map.a} ${map["1"] } 点击
1.2 执行运算
语法:${运算表达式} EL表达式支持如下运算符:
==(eq) !=(ne) <(lt) >(gt) <=(le) >=(ge) &&(and) ||(or) !(not)empty运算符:检查对象是否为null或“空”。
二元运算式:${user!=null? user.name : ""}。运算符比较简单,不多说了……
1.3 获取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对象
具体看下面的例子:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>${paramValues.like[0] } ${paramValues.like[1] } ${header.Accept } ${header["Accept-Encoding"]} ${cookie.JSESSIONID.value } ${initParam.name }EL隐式对象 ${pageContext } <% pageContext.setAttribute("name", "aaa");//map %> ${pageScope.name } <% request.setAttribute("name", "bbb"); %> ${requestScope.name } ${param.name }
1.4调用java方法
EL表达式语法允许开发人员开发自定义函数,以调用java类的方法。示例:${prefix: method(params)}
在EL表达式中调用的只能是java类的静态方法,这个java类的静态方法需要在TLD文件中描述,才可以被EL表达式调用。EL自定义函数用于扩展EL表达式的功能,可以让EL表达式完成普通java程序代码所能完成的功能。 我们在工程test的test包里新建一个名为HtmlFilter的class,如下:public class HtmlFilter { //转义 public static String filter(String message) { if (message == null) return (null); char content[] = new char[message.length()]; message.getChars(0, message.length(), content, 0); StringBuilder result = new StringBuilder(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()); } }
然后在WebRoot下新建一个file,名为test.tld:
A tag library exercising SimpleTag handlers. 1.0 SimpleTagLibrary http://tomcat.apache.org/jsp2-example-taglib filter test.HtmlFilter java.lang.String filter(java.lang.String)
<function>元素用于描述一个EL自定义函数,其中:
<name>子元素用于指定EL自定义函数的名称。 <function-class>子元素用于指定完整的java类名。 <function-signature>子元素用于指定java类中的静态方法的签名,方法签名必须指明方法的返回值类型及各个参数的类型,各个参数之间用逗号分隔。然后新建一个JSP文件,导入<%@ taglib uri="/WEB-INF/test.tld" prefix="fn" %>,在body中写上:${fn:filter("<a href=''>点点</a>") }即可调用HtmlFilter类中的静态方法filer了。
开发EL Function注意事项:
1)编写完标签库描述文件后,需要将它放置到<web应用>\WEB-INF目录中或WEB-INF目录下的除了classes和lib目录之外的任意子目录中。 2)TLD文件中的<uri>元素用来指定该TLD文件的URL,在JSP文件中需要通过这个URL来引入该标签库描述文件。2. SUN公司的EL函数库
由于在JSP页面中显示数据时,经常需要对显示的字符串进行处理,SUN公司针对于一些常见处理定义了一套EL函数库供开发者使用。这些EL函数在JSTL开发包中进行描述,因此在JSP页面中使用SUN公司的EL函数库,需要导入JSTL开发包,并在页面中导入EL函数库,如下所示:
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %> JSTL中的常用EL函数 1) fn:toLowerCase函数将一个字符串中包含的所有字符转换为小写形式,并返回转换后的字符串,它接受一个字符串类型的参数,例如: fn:toLowerCase("Www.Baidu.com")返回字符串为"www.baidu.com" fn:toLowerCase("")返回值为空字符串。 fn.toUpperCase将一个字符串包含的所有字符转换为大写,参数与上面一样 2) fn:trim函数删除一个字符串的首尾空格,并返回删除空格后的结果字符串,它接收一个字符串类型的参数。需要注意的是,fn:trim函数不能删除字符串中间位置的空格。 3)fn:length函数返回一个集合或数组大小,欧返回一个字符串中包含的字符的个数,返回值为int类型。该函数接受一个参数,这个参数可以是<c:forEach>标签的items属性支持的任何类型,包括任意类型的数组、java.util.Collection、java.util.Iterator、java.util.Enumeration、java.util.Map等类的实例对象和字符串。如果fn:length函数的参数为null或者是元素个数为0的集合或数组对象,则函数返回0;如果参数时空字符串,则函数返回0。 4)fn:split函数以指定字符串作为分隔符,将一个字符串分隔成字符串数组并返回这个字符串数组。该函数接收两个字符串类型的参数,第一个参数表示要分隔的字符串,第二个参数表示作为分隔符的字符串。如:fn:split("www.baidu.com",".")[1]的返回值为字符串"baidu"。 5)fn:join函数以一个指定的分隔符,将一个数组中的所有元素合并为一个字符串。fn:join函数接收两个参数,第一个参数是要操作的字符串数组,第二个参数是作为分隔符的字符串。如果fn:join函数的第二个参数是空字符串,则fn:join函数的返回值直接将元素连接起来。例如:假设stringArray是保存在web域中的一个属性,它表示一个值为{"www","baidu","com"}的字符串数组,则fn:join(stringArray,".")返回字符串"www.baidu.com"。fn:join(fn:split("www,baidu,com",","),".")的返回值为字符串"www.baidu.com"。 6)fn:contains函数检测一个字符串中是否包含指定的字符串,返回值为布尔类型。fn:contains函数在比较两个字符串是否相等时是大小敏感的。fn:contains函数接收两个字符串类型的参数,如果第一个参数字符串中包含第二个参数字符串,则fn:contains函数返回true,否则返回false。如果第二个参数的值为空字符串,则fn:contains总是返回true。实际上,fn:contains(string, substring)等价于fn:indexOf(string, substring)!=-1。忽略大小的EL函数:fn:containsIgnoreCase 7)fn:startsWith函数用于检测一个字符串是否是以指定字符串开始的,是则返回true,不是则返回false。fn:startsWith函数接收两个字符串类型的参数,如果第一个参数字符串以第二个参数字符串开始,则函数返回为true,否则函数返回false,如果第二个字符串为空字符串,则函数总是返回true。与之对应的EL函数:fn:endsWith 8)fn:replace函数将一个字符串中包含的指定字符串替换为其它的指定字符串,并返回替换后的结构字符串。fn:replace方法接收三个字符串类型的参数,第一个参数表示要操作的源字符串,第二个参数表示元字符串中要被替换的子字符串,第三个参数表示要被替换成的字符串。如:fn:replace("www baidu com"," ",".")的返回值为字符串"www.baidu.com"。 9)fn:substring函数用于截取一个字符串的子字符串并返回截取到的子字符串。该函数接收三个参数:第一个参数用于指定要操作的源字符串,第二个参数是用于指定截取子字符串开始的索引值,第三个参数是用于指定截取子字符串结束的索引值,第二和第三个参数都是int类型,其值都是从0开始。 10)fn:substringAfter函数用于截取并返回一个字符串中的指定子字符串第一次出现之后的子字符串。该函数接收两个字符串类型的参数:第一个表示要操作的源字符串,第二个表示指定的子字符串。]如:fn:substringAfter("www.baid.com",".")的返回值为字符串"baidu.com"与之对应的EL函数为:fn:substringBefore 11)fn:escapeXml函数表示转义,将xml文件原封不动输出,该函数有一个参数,接收被转义的字符串。EL表达式就总结这么多,如有错误之处欢迎留言指正~