码迷,mamicode.com
首页 > 其他好文 > 详细

Structs2取值的用法

时间:2015-05-26 14:03:28      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:

#、%和$符号在OGNL表达式中经常出现.

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′}” />
<p>The value of key “foo1″ is <s:property value=”#foobar[‘foo1‘]” /></p>
<p>不使用%:<s:url value=”#foobar[‘foo1‘]” /></p>
<p>使用%:<s:url value=”%{#foobar[‘foo1‘]}” /></p>

说明:
"在标志的属性为字符串类型时":
如标志:<s:url>的属性value,其类型是字符串类型.
如标志:<s:property>的属性value,其类型是对象.
所以:
<s:url value=”%{#foobar[‘foo1‘]}” /> -->要使用%
否则,会直接显示成:#foobar[‘foo1‘]

<s:property value="#foobar[‘foo1‘]" /> -->不用使用%

(3)$符号:

$符号主要有两个方面的用途。
2.
在国际化资源文件中,引用OGNL表达式.
在资源文件的国际化字符串中使用OGNL,格式为${表达式},例如:
      validation.require=${getText(fileName)} is required在显示这些国际化字符时,同样有两种方法设置参数的值:
   1. 使用标志的value0、value1...valueN的属性,如:
      <s:text name="validation.required" value0="User Name"/>
   2. 使用param子元素,这些param将按先后顺序,代入到国际化字符串的参数中,例如:
      <s:text name="validation.required">
         <s:param value="User Name"/>
      </s:text>2.2
在Struts 2框架的各种配置文件(validation.xml或struts.xml)中引用OGNL表达式,例如下面的代码片断所示:<validators>
<field name=”intb”>
<field-validator type=”int”>
<param name=”min”>10</param>
<param name=”max”>100</param>
<message>BAction-test校验:数字必须为${min}为${max}之间!</message>  //其值则上面的参数
</field-validator>
</field>
</validators> 

(4)<h2><s:text name="HelloWorld"/></h2> 
    <h2><s:property value="%{getText(‘HelloWorld‘)}"/></h2>
上面的例子用了两种方法来显示国际化字符串,其输出是相同的。其实,这就是Struts 2.0的一个优势,因为它默认支持EL,所示我们可以用getText方法来简洁地取得国际化字符串。

另外更普遍的情况——在使用UI表单标志时, getText可以用来设置label属性,例如:

<s:textfield name="name" label="%{getText(‘UserName‘)}"/>

即:<s:text name="HelloWorld"/>相当于:%{getText(‘UserName‘)}

 

Structs2取值的用法

标签:

原文地址:http://www.cnblogs.com/cangqiongbingchen/p/4530283.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!