ES6和Vue 常用问题总结

ES6

用 async/await 来处理异步和Promise

async

先说一下async的用法,它作为一个关键字放到函数前面,用于表示函数是一个异步函数,因为async就是异步的意思, 异步函数也就意味着该函数的执行不会阻塞后面代码的执行。 写一个async 函数

export default {
        name: 'home',
        components: {},
        data() {
            return {}
        },
        methods: {
            async test3() {
                return "33";
            }
        },
        mounted() {
            console.info(this.test3())
            this.test3().then(result=>{
                console.info(`我輸出了${result}`)
            });
            console.info("我在你後面")
        }
    }

控制台打印
在这里插入图片描述

async 函数返回的是一个promise 对象,如果async 函数中有返回一个值 ,当调用该函数时,内部会调用Promise.solve() 方法把它转化成一个promise 对象作为返回,但如果timeout 函数内部抛出错误呢? 那么就会调用Promise.reject() 返回一个promise 对象

Promise

看完async的实现是不是和Promise很相似,如何用Promise实现,如下图所示
在这里插入图片描述

控制台输出结果
在这里插入图片描述

await

现在写一个函数,让它返回promise 对象,该函数的作用是5s 之后在执行下边的函数
下边延时test5implPromise是可以的,test5implAsync没有获取正确值,可能因为没有拿到定时器的返回值
在这里插入图片描述

控制台输出结果
在这里插入图片描述

现在我们看看代码的执行过程,调用test5函数,它里面遇到了await, await 表示等一下,代码就暂停到这里,不再向下执行了,它等什么呢?等后面的promise对象执行完毕,然后拿到promise resolve 的值并进行返回,返回值拿到之后,它继续向下执行

axios函数利用async/await

在这里插入图片描述

第一种是将test和test1函数变成了Promise,所以同步的是test和test1函数,不是同步的axios函数

控制台输出结果
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值