Struts2基础

[b]OGNL部分[/b]
Object Graph Navigation Language(对象图导航语言)
处理OGNL的最顶层的对象是一个map。通常被引用为context map 或是context。
这个context默认有一个根对象。在表达式中,可对象的属性可以不使用任何标记被引用。使用其他对象需要使用#符号。
OGNL context被设置为ActionContext中。值栈被作为OGNL的跟对象。值栈是一系列对象的集合,但是对于OGNL,就相当于一个对象。
结构如下:
|
|--application
|
|--session
context map---|
|--value stack(root)
|
|--request
|
|--parameters
|
|--attr (searches page, request, session, then application scopes)
|
context map中还含有其他的对象
Action的实例被放入到value stack里。因为value statck是根对象,所以获取action的实例不需要加#,但是获取其他对象需要加上#以告诉OGNL,该对象不是值栈中的
如:
<s:property value="postalCode"/>//放入值栈中的字符串
//以下的不是放入到值栈中的
<s:property value="#session.mySessionPropKey"/> or
<s:property value="#session['mySessionPropKey']"/> or
<s:property value="#request['myRequestPropKey']"/>

ActionContext可以通过一个静态方法拿到ActionContext,如
ActionContext.getContext().getSession().put("mySessionPropKey", mySessionObject);

Struts2中的集合
一个select标签含有list的集合,并有默认值
<s:select label="label" name="name" list="{'name1','name2','name3'}" value="%{'name2'}" />
//struts2的list属性是固定的,真正体现list类型的是值部分,value表示默认值。
一个select标签含有map的集合
<s:select label="label" name="name" list="#{'foo':'foovalue', 'bar':'barvalue'}" />
//map类型,值用#开头,{}里面是key和对应的value
判断一个元素是否在一个集合中:

<s:if test="'foo' not in {'foo','bar'}">
muhahaha
</s:if>
<s:else>
boo
</s:else>

使用OGNL表达式

OGNL要结合struts标签来使用。由于比较灵活,也容易把人给弄晕,尤其是“%”、“#”、“$”这三个符号的使用。由于$广泛应用于EL中,这里重点写%和#符号的用法。

1、“#”符号有三种用途:

(1)、访问非根对象(struts中值栈为根对象)如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属性,直到找到为止。用于过滤和投影(projecting)集合,如books.{?#this.price<100};构造 Map,如#{'foo1':'bar1', 'foo2':'bar2'}。

(2)、用于过滤和投影(projecting)集合,如: books.{?#this.price>35}

books.{?#this.price>35}

(3)、构造Map,如: #{'foo1':'bar1', 'foo2':'bar2'}

#{'foo1':'bar1', 'foo2':'bar2'}这种方式常用在给radio或select、checkbox等标签赋值上。如果要在页面中取一个map的值可以这样写:

<s:property value="#myMap['foo1']"/>

<s:property value="#myMap['foo1']"/>

2、“%”符号的用途是在标签的属性值被理解为字符串类型时,告诉执行环境%{}里的是OGNL表达式。很有点类似javascript里面的eval_r()功能,例如 :

var oDiv = eval_r("document.all.div"+index)

var oDiv = eval_r("document.all.div"+index)

当index变量为1时,语句就会被当作var oDiv = document.all.div1
var oDiv = document.all.div1来执行。%{}就是起这个作用。举例:

<s:set name="myMap" value="#{'key1':'value1','key2':'value2'}"/> 第1行

<s:property value="#myMap['key1']"/> 第2行

<s:url value="#myMap['key1']" />    第3行

<s:set name="myMap" value="#{'key1':'value1','key2':'value2'}"/> 第4行

<s:property value="#myMap['key1']"/> 第5行

<s:url value="#myMap['key1']"/> 第6行

上面的代码第2行会在页面上输出“value1”,而第3行则会输出"#myMap['key1']"这么一个字符串。 如果将第3行改写成这样:

<s:url value="%{#myMap['key1']}"/>

<s:url value="%{#myMap['key1']}"/>

则输出为“value1”。





这说明struts2里不同的标签对ognl的表达式的理解是不一样的。如果当有的标签“看不懂”类似“#myMap['key1']”的语句时,就要用%{}来把这括进去,“翻译”一下了。

3、“$”有两种用途

(1)、在国际化资源文件中,引用OGNL表达式。

(2)、在Struts 2配置文件中,引用OGNL表达式:

<action name="saveUser" class="userAction" method="save">

<result type="redirect">listUser.action?msg=${msg}</result>

</action>

<action name="saveUser" class="userAction" method="save">

<result type="redirect">listUser.action?msg=${msg}</result>

</action>

%是为了让一些struts2识别%{}里面的部分是OGNL表达式
$在Struts2配置文件中表示ognl。
#表示ActionContext.getContext(),代表非根元素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值