前端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
相关文章:
如何在Golang中指定模块版本_使用go.mod控制版本号
如何快速打造个性化非模板自助建站?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
如何选择高效响应式自助建站源码系统?
想学网站制作怎么学,建立一个网站要花费多少?
清除minerd进程的简单方法
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
如何快速搭建二级域名独立网站?
javascript基本数据类型及类型检测常用方法小结
学校免费自助建站系统:智能生成+拖拽设计+多端适配
青岛网站建设如何选择本地服务器?
网站制作公司,橙子建站是合法的吗?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
香港服务器如何优化才能显著提升网站加载速度?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
网站制作软件有哪些,制图软件有哪些?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
建站之星客服服务时间及联系方式如何?
建站之星官网登录失败?如何快速解决?
Bpmn 2.0的XML文件怎么画流程图
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
如何用PHP快速搭建高效网站?分步指南
孙琪峥织梦建站教程如何优化数据库安全?
如何在阿里云香港服务器快速搭建网站?
如何在建站主机中优化服务器配置?
小型网站制作HTML,*游戏网站怎么搭建?
建站之星如何防范黑客攻击与数据泄露?
枣阳网站制作,阳新火车站打的到仙岛湖多少钱?
网站制作的步骤包括,正确网址格式怎么写?
成都网站制作报价公司,成都工业用气开户费用?
网页设计与网站制作内容,怎样注册网站?
建站之星2.7模板:企业网站建设与h5定制设计专题
建站VPS推荐:2025年高性能服务器配置指南
英语简历制作免费网站推荐,如何将简历翻译成英文?
如何在阿里云虚拟服务器快速搭建网站?
C++中引用和指针有什么区别?(代码说明)
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
如何快速搭建高效可靠的建站解决方案?
官网网站制作腾讯审核要多久,联想路由器newifi官网
北京网站制作的公司有哪些,北京白云观官方网站?
建站主机如何选?性能与价格怎样平衡?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
网站制作说明怎么写,简述网页设计的流程并说明原因?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
建站之星会员如何解锁更多建站功能?
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
Swift中switch语句区间和元组模式匹配
*请认真填写需求信息,我们会在24小时内与您取得联系。