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


相关推荐: 如何基于PHP生成高效IDC网络公司建站源码?  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  如何快速上传自定义模板至建站之星?  如何在七牛云存储上搭建网站并设置自定义域名?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  Laravel如何处理CORS跨域请求?(配置示例)  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  如何快速上传建站程序避免常见错误?  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  非常酷的网站设计制作软件,酷培ai教育官方网站?  使用Dockerfile构建java web环境  大连网站制作公司哪家好一点,大连买房网站哪个好?  Laravel storage目录权限问题_Laravel文件写入权限设置  如何构建满足综合性能需求的优质建站方案?  Python高阶函数应用_函数作为参数说明【指导】  微信小程序 input输入框控件详解及实例(多种示例)  Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  如何快速查询网站的真实建站时间?  千库网官网入口推荐 千库网设计创意平台入口  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  php打包exe后无法访问网络共享_共享权限设置方法【教程】  如何在 React 中条件性地遍历数组并渲染元素  HTML 中如何正确使用模板变量为元素的 name 属性赋值  Laravel观察者模式如何使用_Laravel Model Observer配置  Laravel如何使用withoutEvents方法临时禁用模型事件  如何在万网自助建站平台快速创建网站?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  七夕网站制作视频,七夕大促活动怎么报名?  如何用AWS免费套餐快速搭建高效网站?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  如何在建站之星网店版论坛获取技术支持?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  大同网页,大同瑞慈医院官网?  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  Laravel怎么使用artisan命令缓存配置和视图  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  公司网站制作需要多少钱,找人做公司网站需要多少钱?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  如何在香港免费服务器上快速搭建网站?  个人摄影网站制作流程,摄影爱好者都去什么网站?  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Python文件流缓冲机制_IO性能解析【教程】  如何实现javascript表单验证_正则表达式有哪些实用技巧  UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】  Laravel如何保护应用免受CSRF攻击?(原理和示例)