需求要求实现用弹出层发送邮件。提交后层关闭,程序再服务器端响应。
JSON 插件提供了一种名为json的ResultType,一旦为某个Action指定了一个类型为json的Result,则该Result无需映射到任何视图资源。因为JSON插件会负责将Action里的状态信息序列化成JSON格式的数据,并将该数据返回给客户端页面的JavaScript 。
简单地说,JSON插件允许我们在JavaScript中异步调用Action,而且Action不再需要使用视图资源来显示该Action里的状态信息,而是由JSON插件负责将Action里的状态信息返回给调用页面——通过这种方式,就可以完成
Ajax
交互。
1、将struts2的json插件加入web工程的lib,jsonplugin的下载地址:
http://code.google.com/p/jsonplugin/downloads/list
2、struts.xml添加专为ajax使用的package
<
package
name
="ajax"
extends
="json-default"
>
<
action
name
="ajaxRequest"
class
="org.david.struts2.HelloWorld"
>
<
result
type
="json"
></
result
>
</
action
>
</
package
>
3、在页面中引入
jquery的js文件库
<
SCRIPT
type
="text/javascript"
src
="js/jquery-1.2.6.min.js"
></
script
>
<
SCRIPT
type
="text/javascript"
>
function
clickButton()
{
var
url
=
'ajaxRequest.action';
var
params
=
{
name:$('#name').attr('value'),
contactEmail:$('#contactEmail').attr('value'),
subject:$('#subject').attr('value'),
content:$('#content').attr('value')
}
; //通过id获得输入值
jQuery.post(url, params, callbackFun, 'json');
} //url:响应aciton;params:传入参数;callbackFun:响应完成后的回调函数;
function
callbackFun(data)
{
alert("SUCCESS");
}
</
SCRIPT
>
4、action逻辑与普通的ation写法无大区别。
JSON将Action里的状态信息序列化成JSON格式的数据,还不是很理解