Spring MVC前端与后端5种ajax交互方法【总结】
发布时间 - 2026-01-10 23:26:39 点击率:次前端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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
浅谈redis在项目中的应用
linux写shell需要注意的问题(必看)
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
Bootstrap整体框架之JavaScript插件架构
5种Android数据存储方式汇总
Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
C语言设计一个闪闪的圣诞树
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程
利用JavaScript实现拖拽改变元素大小
高端云建站费用究竟需要多少预算?
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
Mybatis 中的insertOrUpdate操作
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
如何彻底卸载建站之星软件?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
如何利用DOS批处理实现定时关机操作详解
如何快速查询网址的建站时间与历史轨迹?
如何在阿里云香港服务器快速搭建网站?
laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
JavaScript如何实现音频处理_Web Audio API如何工作?
微信小程序 配置文件详细介绍
Swift开发中switch语句值绑定模式
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
Python进程池调度策略_任务分发说明【指导】
Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】
如何用免费手机建站系统零基础打造专业网站?
Laravel如何使用Service Container和依赖注入?(代码示例)
活动邀请函制作网站有哪些,活动邀请函文案?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
Laravel如何为API生成Swagger或OpenAPI文档
js实现点击每个li节点,都弹出其文本值及修改
如何用y主机助手快速搭建网站?
JS中对数组元素进行增删改移的方法总结
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
如何在云服务器上快速搭建个人网站?
简单实现Android验证码
Laravel Session怎么存储_Laravel Session驱动配置详解
Python高阶函数应用_函数作为参数说明【指导】
微信推文制作网站有哪些,怎么做微信推文,急?
什么是JavaScript解构赋值_解构赋值有哪些实用技巧

