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 就是已经赋过值的了。

相关推荐
万物得其道者成39 分钟前
前端大整数精度丢失:一次踩坑后的实战解决方案(`json-bigint`)
前端·json
鹏北海1 小时前
移动端 H5 响应式字体适配方案完全指南
前端
姜太公钓鲸2332 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
柳杉3 小时前
使用AI从零打造炫酷医疗数据可视化大屏,源码免费拿!
前端·javascript·数据可视化
凌云拓界3 小时前
前端开发的“平衡木”:在取舍之间找到最优解
前端·性能优化·架构·前端框架·代码规范·设计规范
zhengfei6114 小时前
【XSS payload 】一个经典的XSS payload
前端·xss
简单Janeee4 小时前
[Vue 3 从零到上线]-第四篇:组件化思维——把网页像积木一样拆解
javascript·vue.js·ecmascript
全栈老石5 小时前
手写一个无限画布 #1:坐标系的谎言
前端·canvas
XW01059995 小时前
4-11判断素数
前端·python·算法·素数
J2虾虾5 小时前
Spring Boot中使用@Scheduled做定时任务
java·前端·spring boot