网站首页 > 教程文章 正文
异步函数return问题:
在写VUE前端代码时,会遇到将带有return结果的异步请求函数(如请求后台数据)设置为公共函数,在其他地方调用的场景。但是因为是异步请求数据,实际需要return的值在调用返回时,还未生成,所以导致return的内容为undefined。(见参考[1]的分析)
例如:公共函数和调用方式
//公共函数:根据异步返回的内容确定return值true或false
function a(){
api({
url: "/xxx/xxxx", //后端异步请求
method: "get",
}).then((retData) => {
if(retData.list.length > 0){
return true;
}else{
return false;
}
})
}
//调用位置
checkData(){
var result = a(); //result值为undefined!!
}
调用返回时,因为异步请求还未结束,真正的结果还没有获取到,所以以上代码调用位置result得到的返回值为“undefined”。
解决方案:
- 通过Promise + async/await实现异步return调用
//公共函数:根据异步返回的内容确定return值true或false
function a(){
return new Promise((resolve,reject)=>{
api({
url: "/xxx/xxxx", //后端异步请求
method: "get",
}).then((retData) => {
if(retData.list.length > 0){
resolve(true);
}else{
resolve(false);
}
})
})
}
//调用位置
async checkData(){
var result = await a(); //result值为期望的true或false
}
2. 通过回调函数实现异步return调用
//公共函数:根据异步返回的内容确定return值true或false
function a(func){
api({
url: "/xxx/xxxx", //后端异步请求
method: "get",
}).then((retData) => {
if(retData.list.length > 0){
if(typeof func === "function"){
func(true);
}
}else{
if(typeof func === "function"){
func(false);
}
}
})
}
//调用位置
checkData(){
var result;
a(function(ret){
result = ret; //result值为期望的true或false
});
}
如果在回调函数里面将return返回值赋值给全局变量this.xxx,不能直接this.xxx = ret,需要将this作为变量来引用(参考[2]说明),方法如下:
data() {
return {
result: true;
};
}
methods:{
checkData(){
a(function(ret){
this.result = ret; //这里报错:Uncaught (in promise) TypeError: Cannot read properties of undefined
});
},
checkData2(){
var this_alias = this;
a(function(ret){
this_alias.result = ret; //正确的写法
});
}
}
参考:
猜你喜欢
- 2025-10-19 Nuxt.js 全栈渲染指南:从基础概念到生产环境部署
- 2025-10-19 1天搭建免费微信小程序商店卖茶(3)连载中
- 2025-10-19 Spring Boot3 中实现高效数据权限控制的技术分享
- 2025-10-19 TypeScript 中提升幸福感的 10 个高级技巧
- 2025-10-19 Nginx 高效动静分离:从原理到实战
- 2025-10-19 解决Vue/React路由404的终极方案!Nginx这行代码拯救你的部署
- 2025-10-19 Vue项目子文件夹部署全攻略:从配置到上线,避坑指南在此!
- 2025-10-19 进百度、阿里、腾讯等大厂的 C++ 门槛
- 2025-10-19 小小vite.config.js文件,藏着不少知识点,本文来个大起底。
- 2025-10-19 问题:vue项目打包后,放到二级目录无法访问的解决方案
- 10-19前端错误可观测最佳实践_前端错误处理
- 10-19工作中,前端开发要看项目,怎么查看别人的js项目代码
- 10-19超趣味 Electron+Vue 贪吃蛇游戏Snake
- 10-19AI时代的全栈框架:独立开发者的机会与挑战
- 10-19(CAD集成到网页)网页查看CAD的SDK快速入门
- 10-19前端webpack从入门到精通视频教程文末下载
- 10-19CSS 定位详解_css定位方式
- 10-19React Server Component 从理念到原理
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)