ajax+json+Struts2實(shí)現(xiàn)list傳遞實(shí)例講解
一、首先需要下載JSON依賴的jar包。它主要是依賴如下:
json-lib-2.2.2-jdk15
ezmorph-1.0.4
commons-logging-1.0.4
commons-lang-2.4
commons-collections-3.2.1
commons-beanutils
二、實(shí)例。
1、身份證錯(cuò)誤信息Bean類(lèi)(ErrorCondition.java)
/**
*@Project: excel
*@Author: chenssy
*@Date: 2013-4-4
*@Copyright: chenssy All rights reserved.
*/
public class ErrorCondition {
private String name; // 姓名
private String idCard; // 身份證
private String status; // 錯(cuò)誤狀態(tài)
private String message; // 錯(cuò)誤信息
ErrorCondition(String name,String idCard,String status,String message){
this.name = name;
this.idCard = idCard;
this.status = status;
this.message = message;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getIdCard() {
return idCard;
}
public void setIdCard(String idCard) {
this.idCard = idCard;
}
public String getStatus() {
return status;
}
public void setStatus(String status) {
this.status = status;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
2、JSP頁(yè)面(index.jsp)
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-1.7.2.js"></script>
</head>
<body>
<input type="button" value="點(diǎn)我顯示數(shù)據(jù)" id="clickMe">
<table id="showTable" border="1">
<tr>
<td>姓名</td>
<td>身份證</td>
<td>錯(cuò)誤狀態(tài)</td>
<td>錯(cuò)誤信息</td>
</tr>
</table>
<script>
$("#clickMe").click(function(){
var url = "json/jsonTest.action";
$.ajax({
type:'get',
url:url,
dataType: 'json',
success:function(data){
$.each(data,function(i,list){
var _tr = $("<tr><td>"+list.name+"</td><td>"+
list.idCard+"</td><td>"+list.status+
"</td><td>"+list.message+"</td></tr>");
$("#showTable").append(_tr);
})
}
})
})
</script>
</body>
</html>
3、Action處理類(lèi)(JsonTest_01.java)
/**
*@Project: jsonTest
*@Author: chenssy
*@Date: 2013-4-5
*@Copyright: chenssy All rights reserved.
*/
public class JsonTest_01 {
public String execute() throws IOException{
ErrorCondition r1 = new ErrorCondition("張三", "4306821989021611", "L", "長(zhǎng)度錯(cuò)誤");
ErrorCondition r2 = new ErrorCondition("李四", "430682198902191112","X", "校驗(yàn)錯(cuò)誤");
ErrorCondition r3 = new ErrorCondition("王五", "", "N", "身份證信息為空");
List<ErrorCondition> list = new ArrayList<ErrorCondition>();
list.add(r1);
list.add(r2);
list.add(r3);
//將list轉(zhuǎn)化成JSON對(duì)象
JSONArray jsonArray = JSONArray.fromObject(list);
HttpServletResponse response = (HttpServletResponse) ActionContext.getContext().get(ServletActionContext.HTTP_RESPONSE);
response.setCharacterEncoding("UTF-8");
response.getWriter().print(jsonArray);
return null;
}
}
4、struts.xml配置
<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.1.7//EN"
"http://struts.apache.org/dtds/struts-2.1.7.dtd">
<!-- 指定struts 2的配置文件的跟元素 -->
<struts>
<package name="json" namespace="/json" extends="struts-default">
<action name="jsonTest" class="com.json.action.JsonTest_01" method="execute"></action>
</package>
</struts>
三、運(yùn)行結(jié)果
開(kāi)始頁(yè)面如下:

當(dāng)點(diǎn)擊按鈕后
返回的結(jié)果如下:
- 詳解Struts2中json 相互引用死循環(huán)解決辦法
- Json在Struts中的轉(zhuǎn)換與傳遞方法
- 在Action中以Struts2的方式輸出JSON數(shù)據(jù)的實(shí)例
- struts2通過(guò)action返回json對(duì)象
- struts2+jquery+json實(shí)現(xiàn)異步加載數(shù)據(jù)(自寫(xiě))
- 在Struts2中如何將父類(lèi)屬性序列化為JSON格式的解決方法
- 關(guān)于struts返回對(duì)象json格式數(shù)據(jù)的方法
- Struts2返回json格式數(shù)據(jù)代碼實(shí)例
相關(guān)文章
jsp+mysql數(shù)據(jù)庫(kù)操作常用方法實(shí)例總結(jié)
這篇文章主要介紹了jsp+mysql數(shù)據(jù)庫(kù)操作常用方法,以實(shí)例形式較為詳細(xì)的總結(jié)了JSP操作mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)基本的增、刪、改、查相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10JSP中實(shí)現(xiàn)判斷客戶端手機(jī)類(lèi)型并跳轉(zhuǎn)到app下載頁(yè)面
這篇文章主要介紹了JSP中實(shí)現(xiàn)判斷客戶端手機(jī)類(lèi)型并跳轉(zhuǎn)到app下載頁(yè)面,實(shí)現(xiàn)的原理,是檢測(cè)瀏覽器的 USER-AGENT 這個(gè)header,然后根據(jù)正則表達(dá)式來(lái)確定客戶端類(lèi)型,需要的朋友可以參考下2014-09-09JSP 開(kāi)發(fā)之Servlet解決網(wǎng)頁(yè)緩存問(wèn)題
這篇文章主要介紹了JSP 開(kāi)發(fā)之Servlet解決網(wǎng)頁(yè)緩存問(wèn)題的相關(guān)資料,原理在不需要緩存的頁(yè)面中需要實(shí)現(xiàn)不緩存頁(yè)面,需要的朋友可以參考下2017-08-08點(diǎn)擊地圖div上的按鈕實(shí)現(xiàn)對(duì)地圖數(shù)據(jù)的入庫(kù)操作
在地圖div上添加一個(gè)按鈕并單擊在彈出層的輸入框內(nèi)輸入數(shù)據(jù)后點(diǎn)擊提交按鈕將數(shù)據(jù)提交至數(shù)據(jù)庫(kù),具體的實(shí)現(xiàn)如下,感興趣的朋友可以參考下2013-08-08jsp通過(guò)自定義標(biāo)簽庫(kù)實(shí)現(xiàn)數(shù)據(jù)列表顯示的方法
這篇文章主要介紹了jsp通過(guò)自定義標(biāo)簽庫(kù)實(shí)現(xiàn)數(shù)據(jù)列表顯示的方法,較為詳細(xì)的分析了jsp自定義標(biāo)簽的定義、功能實(shí)現(xiàn)與使用技巧,并附帶了完整的實(shí)例代碼供讀者下載參考,需要的朋友可以參考下2015-10-10AJAX 自學(xué)練習(xí) 無(wú)刷新提交并修改數(shù)據(jù)庫(kù)數(shù)據(jù)并顯示
對(duì)應(yīng)在數(shù)據(jù)庫(kù)中表格 rocars表的msg_id,ccrn兩個(gè)字段?,F(xiàn)在要實(shí)現(xiàn)在界面上修改ccrn的值,ajax提交到response.jsp頁(yè)面,并調(diào)用RocarsEntiy.updateCcrn方法更新對(duì)應(yīng)的ccrn,最后無(wú)刷新顯示2009-09-09XML到Java代碼的數(shù)據(jù)綁定之對(duì)象
XML到Java代碼的數(shù)據(jù)綁定之對(duì)象...2006-10-10JSP動(dòng)態(tài)輸出Excel及中文亂碼的解決
JSP動(dòng)態(tài)輸出Excel及中文亂碼的解決...2006-10-10