前端与后端ajax交互方法总结(附代码)

这次给大家带来前端与后端ajax交互方法总结(附代码),前端与后端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){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; }

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

jsonp+json实现AJAX跨域请求

在jQuery里调用ajax实现异步

以上就是前端与后端ajax交互方法总结(附代码)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2767851.html

(0)
上一篇 2025年3月8日 11:52:56
下一篇 2025年3月7日 12:53:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • jquery查找iframe里元素方法详解

    这次给大家带来jquery查找iframe里元素方法详解,jquery查找iframe里元素的注意事项有哪些,下面就是实战案例,一起来看一下。 问题: 今天在公司是给ckeditor添加一个“是否显示”图片标题的功能 难点: 插件的内容很多…

    编程技术 2025年3月8日
    200
  • jquery获取url与url参数方法详解

    这次给大家带来jquery获取url与url参数方法详解,jquery获取url与url参数的注意事项有哪些,下面就是实战案例,一起来看一下。 使用jquery获取url以及使用jquery获取url参数是我们经常要用到的操作 1、jque…

    编程技术 2025年3月8日
    200
  • AJAX使用代理,JSONP,XHR2实现跨域

    这次给大家带来AJAX使用代理,JSONP,XHR2实现跨域,AJAX使用代理,JSONP,XHR2实现跨域的注意事项有哪些,下面就是实战案例,一起来看一下。 域: 域是WIN2K网络系统的安全性边界。我们知道一个计算机网最基本的单元就是“…

    2025年3月8日
    200
  • AJAX二级联动有哪些实现方法

    这次给大家带来AJAX二级联动有哪些实现方法,AJAX二级联动实现的注意事项有哪些,下面就是实战案例,一起来看一下。 后台Handler.ashx using System;using System.Web;using System.Dat…

    编程技术 2025年3月8日
    200
  • JSONP解决ajax跨域问题(附代码)

    这次给大家带来JSONP解决ajax跨域问题(附代码),JSONP解决ajax跨域问题的注意事项有哪些,下面就是实战案例,一起来看一下。 JSON和JSONP   JSONP和JSON好像啊,他们之间有什么联系吗?   JSON(JavaS…

    编程技术 2025年3月8日
    200
  • jQuery跨域操作iframe里DOM方法

    这次给大家带来jQuery跨域操作iframe里DOM方法,jQuery跨域操作iframe里DOM方法的注意事项有哪些,下面就是实战案例,一起来看一下。 frame目前还是比较流行的,许多地方都通过它来实现特殊的情况。比如说传统的上传、s…

    编程技术 2025年3月8日
    200
  • Angular4性能优化方法总结

    这次给大家带来Angular4性能优化方法总结,Angular4性能优化的注意事项有哪些,下面就是实战案例,一起来看一下。 Summary Angular 4的脏值检测是个老话题了,而理解这个模型是做Angular性能优化的基础。因此,今天…

    编程技术 2025年3月8日
    200
  • js实现字符串与数组去重方法

    这次给大家带来js实现字符串与数组去重方法,js实现字符串与数组去重的注意事项有哪些,下面就是实战案例,一起来看一下。 本文实例讲述了JS实现字符串去重及数组去重的方法。分享给大家供大家参考,具体如下: js数组、字符串去重 /*数组去重*…

    2025年3月8日
    200
  • vue中ajax请求与axios包完美处理

    这次给大家带来vue中ajax请求与axios包完美处理,vue中ajax请求与axios包处理的注意事项有哪些,下面就是实战案例,一起来看一下。 在vue中,经常会用到数据请求,常用的有:vue-resourse、axios 今天我说的是…

    编程技术 2025年3月8日
    200
  • vue父组件调用子组件方法总结

    这次给大家带来vue父组件调用子组件方法总结,vue父组件调用子组件的注意事项有哪些,下面就是实战案例,一起来看一下。 情景:   父组件中引入上传附件的子组件:点击组件可以分别上传对应要求的图片,子组件内部循环可创建多个模块.   父组件…

    2025年3月8日
    200

发表回复

登录后才能评论