ajax 中 success 方法的 return

做前后台交互时会经常用到 ajax,有时候会遇到这样的情况,我们在 a 方法中调用 b 方法,b 方法里是一个 ajax,成功请求后会返回一个结果 data,而我们希望通过 b 方法的返回值获取到 data,我们的代码可能是这样的:

javascript 复制代码
function a() {
	var data = b();
}

function b() {
	$.ajax({
        type : "GET",
        url : "",
        dataType : "json",
        success : function (data) {
        	return data;
        }
    });
}
复制代码

但是,这样直接在 ajax 中的 success 方法里写 return data 是不能达到预期效果的,其实,上面的过程相当于如下的代码:

javascript 复制代码
function a() {
	var data = b();
}

function b() {
	ajax();
}

function ajax() {
	success();  //成功时调用success方法
}

function success() {
	return data;
}
复制代码

调用 ajax 时,可以看做调用了一个叫 ajax 的方法,当成功的时候,ajax 会再调用一个叫 success 的方法,可以看到,此时 data 只是被 return 到 ajax 方法中,而 ajax 并没有继续向外 return,所以,通过 ajax 中 success 方法获取到的返回结果,只是存在于 ajax 内部,b 方法并不知情。

因此,如果希望 b 能返回 data,只需把 data 赋值给 b 中的一个变量,再在 ajax 之后返回这个变量即可:

复制代码
javascript 复制代码
function a() {
	var data = b();
}

function b() {
	var result;
	$.ajax({
        type : "GET",
        url : "",
        dataType : "json",
		async : false,
        success : function (data) {
        	result = data;
        }
    });
	return result;
}

不过需要注意的是,ajax 中需要把 async 属性设置为 false,async 的意思是异步,设置为 false,就代表这个 ajax 不再是异步的,而是同步的。同步异步有什么区别呢?在这个问题中,如果是异步的,则可能 ajax 还没有执行到 success 方法,后面的 return result 就已经执行了,也就获取不到 data 了。而如果设置为同步,那么 ajax 后面的代码就会等待 ajax 执行完毕才执行,这样 return result 就是已经赋过值的了。

相关推荐
梦65031 分钟前
Vue 单页面应用 (SPA) 与 多页面应用 (MPA) 对比
前端·javascript·vue.js
清铎36 分钟前
大模型训练_week3_day15_Llama概念_《穷途末路》
前端·javascript·人工智能·深度学习·自然语言处理·easyui
岛泪1 小时前
把 el-cascader 的 options 平铺为一维数组(只要叶子节点)
前端·javascript·vue.js
lendsomething1 小时前
graalvm使用实战:在java中执行js脚本
java·开发语言·javascript·graalvm
Kiyra2 小时前
阅读 Netty 源码关于 NioEventLoop 和 Channel 初始化部分的思考
运维·服务器·前端
冰暮流星2 小时前
javascript的switch语句介绍
java·前端·javascript
小简GoGo2 小时前
前端常用设计模式快速入门
javascript·设计模式
做科研的周师兄2 小时前
【MATLAB 实战】|多波段栅格数据提取部分波段均值——批量处理(NoData 修正 + 地理信息保真)_后附完整代码
前端·算法·机器学习·matlab·均值算法·分类·数据挖掘
da_vinci_x2 小时前
图标量产:从“手绘地狱”到“风格克隆”?Style Reference 的工业化实战
前端·游戏·ui·prompt·aigc·设计师·游戏美术
利刃大大2 小时前
【ES6】变量与常量 && 模板字符串 && 对象 && 解构赋值 && 箭头函数 && 数组 && 扩展运算符 && Promise/Await/Async
开发语言·前端·javascript·es6