el表达式跟ognl表达式的区别(转)

本文详细介绍了EL表达式和OGNL表达式的特点及使用方法。EL表达式主要用于JSP页面,在不同的作用域中获取数据。OGNL作为Struts2的默认表达式语言,不仅可以读取后台传递的数据,还可以在页面上构建数据。文章还对比了两种表达式的不同之处。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

EL表达式: 
>>单纯在jsp页面中出现,是在四个作用域中取值,page,request,session,application.
>>如果在struts环境中,它除了有在上面的四个作用域的取值功能外,还能从值栈(valuestack)中取值.
>>特点1:${name},name在值栈中的查找顺序是:先从对象栈中取,取到终止,否则,向map中取。
>>特点2:在对象栈的查找顺序是,先从model中找是否有name这个属性,找到终止,否则,找action中是否有name这个全局变量。
>>特点3:${#name},里面的是不带#号的。
>>特点4:如果放在对象栈中的是一个自定义的对象,那么${property}里面可以直接去该对象的属性值,不用这样${object.property}

OGNL表达式:
1:读取从后台传递的值
%{#name}:表示从值栈的map中取值
%{name}:表示从值栈的对象栈中取值
%{#request.name}:表示从request域中取值

2:自己构建数据
a,构建Map
b,构建List

1.区别

用法区别:OGNL是通常要结合Struts 2的标志一起使用,如 struts页面中不能单独使用,el可以单独使用 ${sessionScope.username}

页面取值区别这里写图片描述

2.ognl讲解

OGNL是Struts 2默认的表达式语言。是Object Graphic Navigation Language(对象图导航语言)的缩写,它是一个开源项目。

1.#符号的用途一般有三种。 1)访问非根对象属性,例如示例中的#session.msg表达式,由于Struts 2中值栈被视为根对象,所以访问其他非根对象时,需要加#前缀。实际上,#相当于ActionContext.getContext();;#session.msg表达式相当于ActionContext.getContext().getSession(). getAttribute(”msg”) 。 2)用于过滤和投影(projecting)集合,如示例中的persons.{?#this.age>20}。

3)用来构造Map,例如示例中的#{’foo1′:’bar1′, ’foo2′:’bar2′}。

2.%符号 %符号的用途是在标志的属性为字符串类型时,计算OGNL表达式的值。如下面的代码所示: 构造Map

<s:set name=”foobar” value=”#{’foo1′:’bar1′,foo2:bar2′}” />  
02.<p>The value of key “foo1″ is <s:property value=”#foobar['foo1']” /></p>  
03.<p>不使用%:<s:url value=”#foobar['foo1']” /></p>  
04.<p>使用%:<s:url value=”%{#foobar['foo1']}” /></p>   





01.<s:set name=”foobar” value=”#{’foo1′:’bar1′,foo2:bar2′}” />  
02.<p>The value of key “foo1″ is <s:property value=”#foobar['foo1']” /></p>  
03.<p>不使用%:<s:url value=”#foobar['foo1']” /></p>  
04.<p>使用%:<s:url value=”%{#foobar['foo1']}” /></p>   

3.$符号

OGNLreg.agerange= {min}同${max}之间。 在Struts 2框架的配置文件中引用OGNL表达式,例如下面的代码片断所示:

<validators>  
02.    <field name=”intb”>  
03.            <field-validator type=”int”>  
04.            <param name=”min”>10</param>  
05.            <param name=”max”>100</param>  
06.            <message>BAction-test校验:数字必须为${min}为${max}之间!</message>  
07.        </field-validator>  
08.    </field>  
09.</validators>  





01.<validators>  
02.    <field name=”intb”>  
03.            <field-validator type=”int”>  
04.            <param name=”min”>10</param>  
05.            <param name=”max”>100</param>  
06.            <message>BAction-test校验:数字必须为${min}为${max}之间!</message>  
07.        </field-validator>  
08.    </field>  
09.
10.</validators>  

11. 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值