ognl表达式中的#、%和$

ognl表达式中的#、%和$
“#”主要有三种用途:
1. 访问OGNL上下文和Action上下文,#相当于ActionContext.getContext();下表有几个ActionContext中有用的属性:
 名称作用例子
parameters包含当前HTTP请求参数的Map#parameters.id[0]作用相当于request.getParameter("id")
request包含当前HttpServletRequest的属性(attribute)的Map#request.userName相当于request.getAttribute("userName")
session包含当前HttpSession的属性(attribute)的Map#session.userName相当于session.getAttribute("userName")
application包含当前应用的ServletContext的属性(attribute)的Map#application.userName相当于application.getAttribute("userName")
attr用于按request > session > application顺序访问其属性(attribute)#attr.userName相当于按顺序在以上三个范围(scope)内读取userName属性,直到找到为止
2. 用于过滤和投影(projecting)集合,如books.{?#this.price<100};
   (1)投影:在一个集合中对每一个元素调用相同的方法,或抽取相同的属性,并将结果保存为一个新的集合
   如果employees是一个包含employee对象的列表,那么#employees.{name}将返回所有雇员的名字的列表
   在投影期间,使用#this变量来引用迭代中的当前元素。
  (2)过滤(选择):从集合中选择某些元素,并将结果保存到新的集合中。
   选择操作符有::选择满足条件的所有元素;
                     如:#employees.{?#this.salary>3000}返回薪水大于3000的所有雇员的列表;
                ^:选择满足条件的第一个元素;
                     如:#employees.{^#this.salary>3000}将返回第一个薪水大于3000的雇员的列表;
                $:选择满足条件的最后一个元素;
                    如:#employees.{$#this.salary>3000}将返回最后一个薪水大于3000的雇员的列表;
3. 构造Map,如#{'foo1':'bar1', 'foo2':'bar2'}。
   如果想指定创建的Map类型,可以在左花括号前指定Map实现的类名。例如:#@java.util.HashMap@{'foo1':'bar1','foo2':'bar2'}
   Map通过key来访问,如map['key']或map.key 
   
“%”符号的用途
“%”符号的用途是在标志的属性为字符串类型时,计算OGNL表达式的值

<p><s:url value="#foobar['foo1']" /></p>

<p><s:url value="%{#foobar['foo1']}" /></p>

 

刷新页面,结果如下所示:
#foobar['foo1']?userName=Max+From+parameters;
bar1?userName=Max+From+parameters;

 

“$”有两个主要的用途
用于在国际化资源文件中,引用OGNL表达式,
在Struts 2配置文件中,引用OGNL表达式

<action name="AddPhoto" class="addPhoto">

    <interceptor-ref name="fileUploadStack" />        

   <result type="redirect">ListPhotos.action?albumId=${albumId}</result>

</action>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值