ホームページ >ウェブフロントエンド >jsチュートリアル >フロントエンドとバックエンドの間の ajax 対話方法は何ですか?

フロントエンドとバックエンドの間の ajax 対話方法は何ですか?

php中世界最好的语言
php中世界最好的语言オリジナル
2018-04-02 13:44:372753ブラウズ

今回は、フロントエンドとバックエンド間のajax連携方法とはどのようなものなのか、フロントエンドとバックエンド間のajax連携における注意点について紹介します。 以下は実際的なケースです。一見。 フロントエンドのajaxとバックエンドのSpring MVC

Controller

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

方法 1: URL 経由でパラメータを渡す /auth/getUser?userid='6' などの URL 経由でパラメータをフックする

Server -side メソッドは 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 コード:

りー

私この記事の事例を読んだ後は、その方法を習得したと信じてください。さらに、php 中国語 Web サイトの他の関連記事にも注目してください。

推奨読書:

Ajax データが重複していないか確認する


Ajax インタラクション中に報告された status=parsererror エラーを解決する方法

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

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