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>