主頁 > 知識(shí)庫 > Spring MVC前端與后端5種ajax交互方法【總結(jié)】

Spring MVC前端與后端5種ajax交互方法【總結(jié)】

熱門標(biāo)簽:東平縣地圖標(biāo)注app 電銷機(jī)器人 長(zhǎng)春 上海企業(yè)外呼系統(tǒng)價(jià)錢 大眾點(diǎn)評(píng)400電話怎么申請(qǐng) 河間市地圖標(biāo)注app 立陶宛地圖標(biāo)注 中國(guó)地圖標(biāo)注不明確情況介紹表 怎樣在地圖標(biāo)注文字 地圖標(biāo)注推銷坑人

前端ajax與后端Spring MVC控制器有以下五種數(shù)據(jù)交互方式。(前臺(tái)使用了dhtmlxGrid,后端使用了fastjson)

方式一 通過URL傳參

通過URL掛接參數(shù),如/auth/getUser?userid='6'

服務(wù)器端方法可編寫為:getUser(String userid),也可新增其他參數(shù)如HttpSession, HttpServletRequest,HttpServletResponse,Mode,ModelAndView等。

方式二 單值傳參

前臺(tái)調(diào)用如:

ajaxPost("/base/user/exchangeSort",{"id":rid,"otherid":otherid},function(data,status){

xxxxxx

xxxxxx

});

服務(wù)器端為:

public String exchangeSort(String id, String otherid)

方式三 對(duì)象傳參

前臺(tái)調(diào)用如:

var org={id:id};

ajaxPost("/base/org/getOrgById", org,function(data,textStatus){

xxxx

xxxx

});

服務(wù)器端為:

public Org getOrgById(Org org)

方式四 對(duì)象序列化傳參

前臺(tái)調(diào)用如:

var ueser={id:rowId};

var data=ajaxPost("/base/user/findById",{"userObj":JSON.stringify(user)},null);

或者

var ueser={ };//創(chuàng)建對(duì)象

user["id"]=id;

user["name"]=$("#name").val();

user["dept"]={};//外鍵對(duì)象

user["dept"]["id"]=$("#deptid").val();

ajaxPost("/base/user/addUser",{"userObj":JSON.stringify(user)},function(data){xxxx;xxxxx;});

服務(wù)器端為:

@RequestMapping("/findById")

@ResponseBody

public UserInfo findById(String userObj) {

//使用fastJSON

UserInfo user = JSON.parseObject(userObj, UserInfo.class);

user = (UserInfo) userService.findById(UserInfo.class, user.getId());

return user;

}

方式五 列表傳參

前臺(tái)代碼如:

var objList = new Array();

grid.forEachRow(function(rId) {

var index = grid.getRowIndex(rId);

var obj = {};

obj["id"] = rId;

obj["user"] = {};

obj["user"]["id"] = $("#userId").val();

//不推薦這樣的寫法

//obj["kinShip"] = grid.cells(rId, 1).getValue();

//obj["name"] = grid.cells(rId, 2).getValue();

obj["kinShip"]=grid.cells(rId,grid. getColIndexById ("columnName")).getValue();

obj["name"]=grid.cells(rId,grid.getColIndexById("name")).getValue();

if(grid.cells(rId, 3).getValue()!=null  grid.cells(rId, 3).getValue()!="") {

var str = grid.cells(rId, 3).getValue().split("-");

var day = parseFloat(str[2]);

var month = parseFloat(str[1])-1;

var year = parseInt(str[0]);

var date=new Date();

date.setFullYear(year, month, day);

obj["birth"] = date;

}else {

obj["birth"] ="";

}

obj["politicalStatus"] = grid.cells(rId, 4).getValue();

obj["workUnit"] = grid.cells(rId, 5).getValue();

if (grid.cells(rId, 6).isChecked())

obj["isContact"] ="1";

else

obj["isContact"] ="0";

obj["phone"] = grid.cells(rId, 7).getValue();

obj["remark"] = grid.cells(rId, 8).getValue();

obj["sort"] = index;

objList.push(obj);

});


ajaxPost("/base/user/addUpdateUserHomeList", {

"userHomeList" : JSON.stringify(objList),

"userId" : $("#userId").val()

},function(data, status) {

xxxxx

});

服務(wù)器端:

@RequestMapping("/addUpdateUserHomeList")

@ResponseBody

public String addUpdateUserHomeList(String userHomeList, String userId) {

List userHomes = JSON

.parseArray(userHomeList, UserHome.class);//fastJSON

if (userHomes != null  userHomes.size() > 0) {

try {

userService.addUpdateUserHomeList(userHomes, userId);

} catch (Exception e) {

e.printStackTrace();

}

}

return "200";

}

附上ajaxPost代碼:

function ajaxPost(url,dataParam,callback){ 

var retData=null; 

$.ajax({ 

type: "post", 

url: url, 

data: dataParam, 

dataType: "json", 

success: function (data,status) { 

// alert(data); 

retData=data; 

if(callback!=nullcallback!=""callback!=undefined) 

callback(data,status); 

}, 

error: function (err,err1,err2) { 

alertMsg.error("調(diào)用方法發(fā)生異常:"+JSON.stringify(err)+"err1"+ JSON.stringify(err1)+"err2:"+JSON.stringify(err2)); 

} 

}); 

return retData; 

}

以上這篇Spring MVC前端與后端5種ajax交互方法【總結(jié)】就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • spring mvc 實(shí)現(xiàn)獲取后端傳遞的值操作示例
  • laypage+SpringMVC實(shí)現(xiàn)后端分頁
  • Spring MVC前后端的數(shù)據(jù)傳輸?shù)膶?shí)現(xiàn)方法
  • 輕松玩轉(zhuǎn)BootstrapTable(后端使用SpringMVC+Hibernate)
  • SpringMVC前端和后端數(shù)據(jù)交互總結(jié)
  • java web SpringMVC后端傳json數(shù)據(jù)到前端頁面實(shí)例代碼
  • SpringMVC后端返回?cái)?shù)據(jù)到前端代碼示例

標(biāo)簽:四川 遼寧 營(yíng)口 本溪 玉樹 銅川 內(nèi)江 益陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Spring MVC前端與后端5種ajax交互方法【總結(jié)】》,本文關(guān)鍵詞  Spring,MVC,前端,與,后端,5種,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Spring MVC前端與后端5種ajax交互方法【總結(jié)】》相關(guān)的同類信息!
  • 本頁收集關(guān)于Spring MVC前端與后端5種ajax交互方法【總結(jié)】的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章