一、什么是 EL 语言。
EL是 JSP 2.0 引入的一种计算和输出 Java 对象的简单语音。
二、EL 语言的作用。
为了使JSP写起来更加简单。表达式语言的灵感来自于 ECMAScript 和 XPath 表达式语言,它提供了在 JSP 中简化表达式的方法。它是一种简单的语言,基于可用的命名空间(PageContext 属性)、嵌套属性和对集合、操作符(算术型、关系型和逻辑型)的访问符、映射到 Java 类中静态方法的可扩展函数以及一组隐式对象。
三、使用 EL 语言前的配置。
1、导入standard.jar。
2、在需要使用 EL 语音的页面加上<%@ page isELIgnored=”false” %>。
注意 <%@ page isELIgnored=”true” %> 表示是否禁用EL语言,TRUE表示禁止.FALSE表示不禁止.JSP2.0中默认的启用EL语言。
3、对于整个JSP应用程序,要修改WEB.XML配置(tomcat5.0.16默认是支持EL的)
<jsp-property-group>
<description> For config the ICW sample application </description>
<display-name>JSPConfiguration </display-name>
<url-pattern>/jsp/datareset.jsp </url-pattern>
<el-ignored>true< / el-ignored> < / el-ignored>
<page-encoding>UTF-8</page-encoding>
<scripting-invalid>true</scripting-invalid>
<include-prelude>/jsp/prelude.jspf</include-prelude>
<include-coda>/jsp/coda.jspf</include-coda>
</jsp-property-group>
四、如何使用 EL 表达式。
1、EL 的内置对象。
内置对象:pageScope、requestScope、sessionScope、applicationScope,如果未指定scope,默认从 pageScope 到 applicationScope一次扩大范围查找属性名,也可以使用 xxxScope.属性名 直接指定在某个 scope 查找,如:
${ requestScope.tom }
2、语法结构:${expression}
3、[ ]与.运算符。
EL 提供.和[]两种运算符来存取数据。如:
${student.name}
${studentList[0].name}
当要存取的属性名称中包含一些特殊字符,如.或?等并非字母或数字的符号,就一定要使用“[ ]“。如:
${ student.My-Name} <!-- ${ student.My-Name} 写法不正确,应该改为下面这种 -->
${ student["My-Name"] }
如果要动态取值时,就可以用“[ ]“来做,而“.“无法做到动态取值。如:
${ sessionScope.student[property] } <!-- 其中 property 是一个变量,动态取对象的属性,如"id", "name"等等 -->
4、使用 EL 取出内置对象的数据。
(1)、普通对象和对象属性。
服务器端:
request.setAttribute(“student”, student);
在浏览器上打印出服务器端绑定的数据:
${ student } <!-- 相当于执行了 student.toString(); -->
${ student.name } <!-- 相当于执行了 student.getName(); -->
${ student.teacher.name } <!-- 相当于执行了 student.getTeacher().getName(); -->
(2)、数组中的数据。
服务器端:
String[] nameArray = new String[]{"Tom", "Lucy", "Lilei"};
request.setAttribute(“nameArray”,nameArray);
Student[] students = new Student[3];
students[0] = stu1;
students[1] = stu2;
students[2] = stu3;
request.setAttribute(“students”,students);
在浏览器上打印出服务器端绑定的数组数据:
${ nameArray[0] } <!-- Tom -->
${ nameArray[1] } <!-- Lucy -->
${ nameArray[2] } <!-- Lilei -->
${ students[0].id } <!-- 输出第一个学生的ID -->
${ students[1].name } <!-- 输出第二个学生的name -->
${ students[2].teacher.name } <!-- 输出第三个学生的老师的name -->
(3)、List中的数据。
服务器端:
List<Student> studentList=new ArrayList<Student>();
studentList.add(stu1);
studentList.add(stu2);
studentList.add(stu3);
request.setAttribute(“studentList”,studentList);
在浏览器上打印出服务器端绑定的List数据:
${ studentList[0].id } <!-- 输出第一个学生的ID -->
${ studentList[1].name } <!-- 输出第二个学生的name -->
${ studentList[2].teacher.name } <!-- 输出第三个学生的老师的name -->
(4)、Map中的数据。
服务器端:
Map<String, Student> studentMap = new HashMap<String, Student>();
studentMap.put("Tom", stu1);
studentMap.put("Lucy", stu2);
studentMap.put("Lilei", stu3);
request.setAttribute(“studentMap”,studentMap);
在浏览器上打印出服务器端绑定的Map数据:
${ studentMap.Tom.id } <!-- 输出第一个学生的ID -->
${ studentMap.Lucy.name } <!-- 输出第二个学生的name -->
${ studentMap.Lilei.teacher.name } <!-- 输出第三个学生的老师的name -->