ホームページ >ウェブフロントエンド >jsチュートリアル >Spring MVC フロントエンドとバックエンド間の 5 つの ajax 対話メソッド

Spring MVC フロントエンドとバックエンド間の 5 つの ajax 対話メソッド

亚连
亚连オリジナル
2018-05-22 16:20:012619ブラウズ

それでは、Spring MVC フロントエンドとバックエンドの間の 5 つの ajax 対話メソッドに関する記事をお届けします。今からそれを皆さんと共有し、皆さんの参考にしてください。

フロントエンドの ajax とバックエンドの Spring MVC コントローラーには、次の 5 つのデータ対話メソッドがあります。 (dhtmlxGrid はフロントエンドで使用され、fastjson はバックエンドで使用されます)

方法 1: URL 経由でパラメーターを渡す

/auth/getUser?userid='6' などの URL 経由でパラメーターをフックします

サーバー側メソッドは getUser(String userid) として記述できます。また、HttpSession、HttpServletRequest、HttpServletResponse、Mode、ModelAndView などの他のパラメータを追加することもできます。

メソッド 2 単一値パラメータの受け渡し

次のようなフォアグラウンド呼び出し:

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

xxxxxx

xxxxxx

});

サーバー側は:

public String ExchangeSort(String id, String otherid)

メソッド3 オブジェクトパラメータの受け渡し

フロントエンドの呼び出しは次のとおりです:

var org={id:id};

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

xxxx

xxxx

});

サーバーサイドは次のとおりです:

public Org getOrgById(Org org)

4 オブジェクトのシリアル化されたパラメータ転送メソッド

フロントエンド呼び出しは次のようになります:

var ueser={id:rowId};

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

または

var ueser={ };//创建对象

user["id"]=id;

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

user["dept"]={};//外键对象

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

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

サーバー側は次のようになります:

@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;

}

5 つのリストパラメータ

フロントエンドコードは次のようなものです:

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

});

サーバー側:

@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!=null&&callback!=""&&callback!=undefined) 

callback(data,status); 

}, 

error: function (err,err1,err2) { 

alertMsg.error("调用方法发生异常:"+JSON.stringify(err)+"err1"+ JSON.stringify(err1)+"err2:"+JSON.stringify(err2)); 

} 

}); 

return retData; 

}

上記は私が皆さんに役立つことを願ってまとめたものです。未来のみんなへ。

関連記事:

Ajaxと対話するときに常にstatus=parsererrorを報告する解決策

実装コードが重複していないかどうかを確認するAjax検証

phpcmsのような関数のAjax実装(画像とテキストのチュートリアル) )

以上がSpring MVC フロントエンドとバックエンド間の 5 つの ajax 対話メソッドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。