struts2+jquery+json

 

 Struts2+JQuery+JSON集成


细节部分我就不多讲了,因为我也不会,就讲讲我是如何调试出来我的第一个JSON使用的吧

采用的框架有:Struts2 、 JQuery 、 JSON


按着步骤来吧:


 1.新建一个Web工程


导入包列表:

 


 目录结构如图:

 


 2.建立实体类User

view plaincopy to clipboardprint?
package com.school.pojo;  
 
public class User {  
private String user;  
private int age;  
public String getUser() {  
    return user;  
}  
public void setUser(String user) {  
    this.user = user;  
}  
public int getAge() {  
    return age;  
}  
public void setAge(int age) {  
    this.age = age;  
}  

package com.school.pojo;

public class User {
private String user;
private int age;
public String getUser() {
 return user;
}
public void setUser(String user) {
 this.user = user;
}
public int getAge() {
 return age;
}
public void setAge(int age) {
 this.age = age;
}
}
 


 3.建立Action JsonAction

view plaincopy to clipboardprint?
public class JsonAction extends ActionSupport{  
private User user;  
//用于记录返回结果  
private String result;  
//省略相应的get和set方法   
@SuppressWarnings("static-access")  
public String execute() throws Exception {  
//将要返回的user实体对象进行json处理  
JSONObject jo = JSONObject.fromObject(this.user);  
System.out.println(jo);  
//调用json对象的toString方法转换为字符串然后赋值给result  
this.result = jo.toString();  
return this.SUCCESS;  
}  

public class JsonAction extends ActionSupport{
private User user;
//用于记录返回结果
private String result;
//省略相应的get和set方法
@SuppressWarnings("static-access")
public String execute() throws Exception {
//将要返回的user实体对象进行json处理
JSONObject jo = JSONObject.fromObject(this.user);
System.out.println(jo);
//调用json对象的toString方法转换为字符串然后赋值给result
this.result = jo.toString();
return this.SUCCESS;
}
}

 


 4.建立struts.xml文件

view plaincopy to clipboardprint?
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE struts PUBLIC  
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
    "http://struts.apache.org/dtds/struts-2.0.dtd"> 
<struts> 
<constant name="struts.i18n.encoding" value="UTF-8"></constant> 
<package name="ttttt" extends="json-default"> 
<action name="jsonAction" class="action.JsonAction"> 
<result type="json" > 
<!-- 因为要将reslut的值返回给客户端,所以这样设置 --> 
<!-- root的值对应要返回的值的属性 --> 
<param name="root"> 
result  
</param> 
</result> 
</action> 
</package> 
</struts> 
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.i18n.encoding" value="UTF-8"></constant>
<package name="ttttt" extends="json-default">
<action name="jsonAction" class="action.JsonAction">
<result type="json" >
<!-- 因为要将reslut的值返回给客户端,所以这样设置 -->
<!-- root的值对应要返回的值的属性 -->
<param name="root">
result
</param>
</result>
</action>
</package>
</struts>

 


 5.编写index.jsp文件

view plaincopy to clipboardprint?
<%@ page language="java" pageEncoding="UTF-8"%>  
 
<%@ taglib prefix="s" uri="/struts-tags"%>  
 
<%  
 
String path = request.getContextPath();  
 
String basePath = request.getScheme() + "://" 
 
+ request.getServerName() + ":" + request.getServerPort()  
 
+ path + "/";  
 
%>  
 
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
 
<html>  
 
<head>  
 
<base href="<%=basePath%>">  
 
 
<title>My JSP 'index.jsp' starting page</title>  
 
<meta http-equiv="pragma" content="no-cache">  
 
<meta http-equiv="cache-control" content="no-cache">  
 
<meta http-equiv="expires" content="0">  
 
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  
 
<meta http-equiv="description" content="This is my page">  
 
 
<!-- basePath用来获取js文件的绝对路径 -->  
 
<mce:script type="text/javascript" src="<%=basePath%><!--  
js/jquery.js">  
// --></mce:script>  
 
<mce:script type="text/javascript" src="<%=basePath%><!--  
js/index.js">  
// --></mce:script>  
 
<s:head theme="ajax" />  
 
</head>  
 
 
<body>  
 
<div id="result">  
 
</div>  
 
<s:form name="userForm" action="" method="post">  
 
<s:textfield label="用户名" name="user.name" />  
 
<s:textfield label="年龄" name="user.age" />  
 
<button>  
 
提交  
 
</button>  
 
</s:form>  
 
 
</body>  
 
</html> 
<%@ page language="java" pageEncoding="UTF-8"%>

<%@ taglib prefix="s" uri="/struts-tags"%>

<%

String path = request.getContextPath();

String basePath = request.getScheme() + "://"

+ request.getServerName() + ":" + request.getServerPort()

+ path + "/";

%>


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

<base href="<%=basePath%>">


<title>My JSP 'index.jsp' starting page</title>

<meta http-equiv="pragma" content="no-cache">

<meta http-equiv="cache-control" content="no-cache">

<meta http-equiv="expires" content="0">

<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">

<meta http-equiv="description" content="This is my page">


<!-- basePath用来获取js文件的绝对路径 -->

<mce:script type="text/javascript" src="<%=basePath%><!--
js/jquery.js">
// --></mce:script>

<mce:script type="text/javascript" src="<%=basePath%><!--
js/index.js">
// --></mce:script>

<s:head theme="ajax" />

</head>


<body>

<div id="result">

</div>

<s:form name="userForm" action="" method="post">

<s:textfield label="用户名" name="user.name" />

<s:textfield label="年龄" name="user.age" />

<button>

提交

</button>

</s:form>


</body>

</html>

 


 6.在WebRoot目录下建立js文件件,将jquery.js文件放到文件夹下,然后再建立文件index.js


view plaincopy to clipboardprint?
$(document).ready(function() {  
 
 
// 直接把onclick事件写在了JS中  
 
$("button").click(function() {  
 
// 序列化表单的值  
 
var params = $("input").serialize();  
 
 
$.ajax({  
 
 
// 后台处理程序  
 
url : "jsonAction.action",  
 
 
// 数据发送方式  
 
type : "post",  
 
 
// 接受数据格式  
 
dataType : "json",  
 
 
// 要传递的数据  
 
data : params,  
 
 
// 回传函数  
 
success : update_page  
 
 
});  
 
});  
 
 
});  
 
function update_page(result) {   
 
var json = eval( "("+result+")" );  
 
var str = "姓名:" + json.name + "<br />"; str += "年龄:"   
 
+ json.age + "<br />";  
 
$("#result").html(str);  
 
 

$(document).ready(function() {


// 直接把onclick事件写在了JS中

$("button").click(function() {

// 序列化表单的值

var params = $("input").serialize();


$.ajax({


// 后台处理程序

url : "jsonAction.action",


// 数据发送方式

type : "post",


// 接受数据格式

dataType : "json",


// 要传递的数据

data : params,


// 回传函数

success : update_page


});

});


});

function update_page(result) {

var json = eval( "("+result+")" );

var str = "姓名:" + json.name + "<br />"; str += "年龄:"

+ json.age + "<br />";

$("#result").html(str);


}

 


 7.运行前效果:

要的是效果,布局就不整了

 


运行后效果:

 


网上相关的信息太少了,很多Struts2+JQuery+JSON的教程,点开链接之后都是那几篇文章转了又转,遇到问题真的很想找到有用的信息,或许是我太笨了,找不到,或许就是网上相关的信息就很少。这个实例很简单是不是,但是为了调试出这个程序,我费了一天的时间。


上面的实例成功了,但是问题又出来了

视图类型仅仅设置了json

那么输入校验出错的时候怎么显示?

部分内容转自:http://blog.csdn.net/fengda2870/archive/2009/04/06/4052527.aspx

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/09/30/4621641.aspx

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/09/30/4621641.aspx

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/icejadelove/archive/2009/09/30/4621641.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值