广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue+axios methods方法return取不到值问题及解决
  • 675
分享到

vue+axios methods方法return取不到值问题及解决

vue axios methods returnmethods方法returnreturn取不到值 2022-11-13 18:11:29 675人浏览 安东尼
摘要

目录Vue+axiOS methods方法return取不到值原因解决方法vue返回axios的return值,很容易undefined获取axios的return值vue+axio

vue+axios methods方法return取不到值

vue写了一个判断电话号码是否存在的方法无法取到返回值

原因

因为axios是异步操作,在获取返回值时请求操作还没有完成就已经完成了赋值操作,所以结果的undefined。

解决方法

使用async + await。async声明方法为异步方法,await等待异步操作执行完。

另外: 异步方法返回值为peomise<>,接收时需要.then(res=>{})

vue返回axios的return值,很容易undefined

获取axios的return值

1.如果直接在.then里return,得到的值就是undefined,如下

map(){
    let a=[]
    mapChina().then(res=>{    //调用axios自己封装的接口
        a=res 
    })
    return a
}
const b=this.map()        //结果是undefined

因axios返回值是异步操作,获取返回值时,请求操作还未完成,就已经执行了赋值,导致结果位undefined

2.解决方法使用async….await,async声明发放为异步方法,await等待异步操作执行完毕

async map(){
    let a=[]
    await mapChina().then(res=>{    //调用axios自己封装的接口
        a=res 
    })
    return a
}
const b=await this.map()         //结果正确返回a

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: vue+axios methods方法return取不到值问题及解决

本文链接: https://www.lsjlt.com/news/169362.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作