• Async/Await 来简化Promise(以Element-ui 询问框为例)


    什么是Async/Await,及其作用

    ① async/await是ES7新特性
    ② async/await是写异步代码的新方式,以前的方法有回调函数和Promise
    ③ async/await是基于Promise实现的,它不能用于普通的回调函数
    ④ async/await与Promise一样,是非阻塞的
    ⑤ async/await使得异步代码看起来像同步代码,这正是它的魔力所在

    await 必须写在 async 函数中, 但 async 函数中可以没有 await,如果 await 的 Promise 失败了, 就会抛出异常, 需要通过 try...catch 捕获处理。

    Promise 中不能自定义使用 try/catch 进行错误捕获,但是在 Async/await 中可以像处理同步代码处理错误

    使用await/async时,你不再需要那么多箭头函数,这样你就可以像调试同步代码一样跳过await语句。

    Element-ui 询问框 Promise写法

    挂载组件到实例上

    import {

      Message,

      MessageBox,

    } from 'element-ui'

    Vue.prototype.$Msg = Message

    Vue.prototype.$queding = MessageBox.confirm

    代码逻辑:

    点击了删除按钮,显示询问,两个按钮对应两个执行方式,点击确定还有两种情况,删除成功,删除失败

    组件封装后续使用了Promise

    1. // 删除用户的相关操作
    2. deleteUser(id) {
    3. this.$queding('此操作将永久删除该用户, 是否继续?', '提示', {
    4. confirmButtonText: '确定',
    5. cancelButtonText: '取消',
    6. type: 'warning'
    7. }).then(() => {
    8. this.$http.delete(`users/${id}`).then(() =>{
    9. this.$Msg({
    10. type: 'success',
    11. message: '删除成功!'
    12. });
    13. this.getUserList()
    14. }).catch(() => {
    15. this.$Msg.error('删除用户失败!')
    16. })
    17. }).catch(() => {
    18. this.$Msg({
    19. type: 'info',
    20. message: '已取消删除'
    21. });
    22. });

     使用Async/Await

    1. async deleteUser(id){
    2. //弹窗询问用户是否删除数据
    3. const confirmResult = await this.$queding(
    4. '此操作将永久删除该用户, 是否继续?',
    5. '提示',
    6. {
    7. confirmButtonText: '确定',
    8. cancelButtonText: '取消',
    9. type: 'warning'
    10. }
    11. ).catch(err => err)
    12. // 如果用户确认删除,则返回值为字符串 confirm
    13. // 如果用户取消删除,则返回值为字符串 cancel
    14. // console.log(confirmResult)
    15. if (confirmResult !== 'confirm'){
    16. return this.$Msg.info('已取消删除')
    17. }
    18. const {data:res} = await this.$http.delete(`users/${id}`)
    19. if (res.meta.status !== 200) return this.$Msg.error('删除用户失败!')
    20. this.$Msg.success('删除用户成功!')
    21. // 删除成功后 重新获取用户列表
    22. await this.getUserList()
    23. },

    async/await使得异步代码看起来像同步代码,这正是它的魔力所在

  • 相关阅读:
    FFmpeg开发笔记(五十七)使用Media3的Transformer加工视频文件
    初识C++
    npm run serve与npm run dev的区别
    数据库update、delete误操作,使用binlog2sql手动回退
    ERP对接淘宝/天猫/京东/拼多多商品详情数据API接口
    【C++】基础语句(学习笔记)
    【运维语音播报】Zabbix告警语音声光播报的实现
    智慧屏内核崩溃问题分析
    【力扣】674. 最长连续递增序列 <贪心模拟、动规>
    CentOS服务端命令大全
  • 原文地址:https://blog.csdn.net/benlalagang/article/details/126246961