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>

你可能感兴趣的:(struts)