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

相关推荐
frontend丶CV1 分钟前
useMemo
前端·react.js
明月_清风2 分钟前
基于 node-rtsp-stream 的 Web 直播方案详解
前端
DEMO派6 分钟前
前端处理用户离开当前页面的方案及对比解析
前端
LFly_ice6 分钟前
Next-4-路由导航
开发语言·前端·javascript
chilavert3187 分钟前
技术演进中的开发沉思-267 Ajax:拖放功能
前端·javascript·ajax
守护砂之国泰裤辣9 分钟前
el-select 选项偏移 到左边 左上角
前端·javascript·vue.js
明月_清风12 分钟前
Chrome 插件开发科普:从零开始打造你的浏览器小工具
前端
若梦plus14 分钟前
Node.js之TypeScript支持
前端·typescript
马优晨14 分钟前
cssnano 在前端工程化中的应用
前端·cssnano应用·cssnano 是什么·cssnano介绍·css优化
若梦plus14 分钟前
Node.js基础与常用模块
前端·node.js