时间:2021-05-26
前端ajax与后端Spring MVC控制器有以下五种数据交互方式。(前台使用了dhtmlxGrid,后端使用了fastjson)
方式一 通过URL传参
通过URL挂接参数,如/auth/getUser?userid='6'
服务器端方法可编写为:getUser(String userid),也可新增其他参数如HttpSession, HttpServletRequest,HttpServletResponse,Mode,ModelAndView等。
方式二 单值传参
前台调用如:
ajaxPost("/base/user/exchangeSort",{"id":rid,"otherid":otherid},function(data,status){xxxxxxxxxxxx});服务器端为:
public String exchangeSort(String id, String otherid)
方式三 对象传参
前台调用如:
var org={id:id};ajaxPost("/base/org/getOrgById", org,function(data,textStatus){xxxxxxxx});服务器端为:
public Org getOrgById(Org org)
方式四 对象序列化传参
前台调用如:
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")@ResponseBodypublic UserInfo findById(String userObj) {//使用fastJSONUserInfo user = JSON.parseObject(userObj, UserInfo.class);user = (UserInfo) userService.findById(UserInfo.class, user.getId());return user;}方式五 列表传参
前台代码如:
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";elseobj["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")@ResponseBodypublic String addUpdateUserHomeList(String userHomeList, String userId) {List userHomes = JSON.parseArray(userHomeList, UserHome.class);//fastJSONif (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; }以上这篇Spring MVC前端与后端5种ajax交互方法【总结】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
之前总结过flask里的基础知识,现在来总结下flask里的前后端数据交互的知识,这里用的是Ajax一、post方法1、post方法的位置:在前端HTML里,绑
前端中常常用的与后端交换数据的话,通常是要用到ajax这种方法的但是交互的方式有很多种,很多取决于你后端的属性,我这儿主要列举我目前项目比较常用的两种方式--一
前言前后端交互如何保证安全性?前后端交互如何保证安全性?web与后端,andorid与后端,ios与后端,像这种类型的交互其实就属于典型的前端与后端进行交互。在
Vue-CLI项目-axios模块前后端交互(类似ajax提交)08.31自我总结,内容如下:Vue-CLI项目-axios前后端交互一.模块的安装npmins
JS中很多地方会使用Ajax与后台进行数据交互。Ajax是通过http,使得JS与后端进行数据通信,由于Ajax的异步特性,可以使多个Ajax请求同时访问后端,