全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Spring MVC前端与后端5种ajax交互方法【总结】

前端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){

xxxxxx

xxxxxx

});

服务器端为:

public String exchangeSort(String id, String otherid)

方式三 对象传参

前台调用如:

var org={id:id};

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

xxxx

xxxx

});

服务器端为:

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")

@ResponseBody

public UserInfo findById(String userObj) {

//使用fastJSON

UserInfo 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";

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; 

}

以上这篇Spring MVC前端与后端5种ajax交互方法【总结】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# 前端后端交互  # spring mvc 和ajax异步交互完整实例代码  # Springmvc和ajax如何实现前后端交互  # SpringMVC和Ajax的交互详解(手工处理)  # 后端  # 给大家  # 使用了  # 也可  # 希望能  # 这篇  # 五种  # 小编  # 大家多多  # 挂接  # 序列化  # getOrgById  # org  # var  # textStatus  # public  # UserInfo  # xxxx  # function  # otherid 


相关文章: 制作旅游网站html,怎样注册旅游网站?  如何在IIS7中新建站点?详细步骤解析  黑客如何通过漏洞一步步攻陷网站服务器?  c# 服务器GC和工作站GC的区别和设置  常州企业建站如何选择最佳模板?  建站与域名管理如何高效结合?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  常州企业网站制作公司,全国继续教育网怎么登录?  如何零基础开发自助建站系统?完整教程解析  电商平台网站制作流程,电商网站如何制作?  如何通过网站建站时间优化SEO与用户体验?  php8.4新语法match怎么用_php8.4match表达式替代switch【方法】  如何在IIS中新建站点并配置端口与物理路径?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  如何在阿里云高效完成企业建站全流程?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  如何在建站之星绑定自定义域名?  如何在阿里云虚拟服务器快速搭建网站?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  建站中国官网:模板定制+SEO优化+建站流程一站式指南  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  开心动漫网站制作软件下载,十分开心动画为何停播?  网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?  兔展官网 在线制作,怎样制作微信请帖?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  如何快速查询网址的建站时间与历史轨迹?  如何在腾讯云免费申请建站?  如何在宝塔面板中创建新站点?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  香港服务器网站推广:SEO优化与外贸独立站搭建策略  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  如何在阿里云域名上完成建站全流程?  实例解析Array和String方法  济南专业网站制作公司,济南信息工程学校怎么样?  想学网站制作怎么学,建立一个网站要花费多少?  浅析上传头像示例及其注意事项  定制建站流程解析:需求评估与SEO优化功能开发指南  西安专业网站制作公司有哪些,陕西省建行官方网站?  如何注册花生壳免费域名并搭建个人网站?  建站主机功能解析:服务器选择与快速搭建指南  如何通过虚拟机搭建网站?详细步骤解析  如何通过免费商城建站系统源码自定义网站主题与功能?  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  如何快速搭建FTP站点实现文件共享?  如何在七牛云存储上搭建网站并设置自定义域名?  5种Android数据存储方式汇总 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。