vue关于Promise的使用方式

 更新时间:2024年06月18日 09:09:25   作者:曾令胜  
这篇文章主要介绍了vue关于Promise的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Promise基本概念

Promise是一个构造函数,所以可以 new 出一个Promise的实例;

  • 在Promise上有两个函数 resolve (成功之后的回调函数)和 reject (失败后的回调函数);
  • 在Promise构造函数的prototype属性上,有一个 .then() 方法。

所以只要是Promise构造函数创建的实例,都可以访问到 .then()方法;

  • Promise表示一个一步操作,每当我们new一个Promise的实例,这个实例就代表具体的 异步 操作
  • Promise创建的实例,是一个异步操作,这个异步操作结果,

只有两种结果:

  • 状态1:异步执行 成功,需要在内部调用成功的回调函数resolve把结果返回给调用者
  • 状态2:异步执行 失败,需要在内部调用失败的回调函数reject把结果返回调用者

由于Promise的实例是一个异步操作,所以内部拿到操作结果后,无法使用return把操作结果返回给调用者 ,

这个时候只能使用 回调函数 的形式,把成功或失败的结果,返回给调用者,

具体:

  • 我们可以在new出来的Promise实例上,调用 .then()方法
  • 预先为这个Promise异步操作,指定成功(resolve)和失败(reject)回调函数

使用实例

store.js的actions中添加increment方法。测试reject的使用方法。

 increment (context) {
      return new Promise((resolve, reject) => {
        setTimeout(() => {
          reject(new Error('2222222'))
        }, 1000)
      })
    }

调用increment

 handleActionDecrease () {
      this.$store.dispatch('increment').then((data) => {
        console.log(data)
        console.log(this.$store.state.count)
      }).catch((error) => {
        console.log(error)
      })
    }

返回结果为

store.js的actions中添加increment方法。

测试resolve的使用方法。

increment ({ commit }) {
      return new Promise((resolve, reject) => {
        setTimeout(() => {
          resolve("1111")
        reject(new Error('2222222'))
      }, 1000)
    })
    },

调用

 handleActionDecrease () {
      this.$store.dispatch('increment').then((data) => {
        console.log(data)
        console.log(this.$store.state.count)
      }).catch((error) => {
        console.log(error)
      })
    }

输出

总结

  • resolve —>对应then
  • reject —>对应catch

另外,只有调用了resolve 或者reject 才会触发 then 和 catch

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue实现的上拉加载更多数据/分页功能示例

    vue实现的上拉加载更多数据/分页功能示例

    这篇文章主要介绍了vue实现的上拉加载更多数据/分页功能,涉及基于vue的事件响应、数据交互等相关操作技巧,需要的朋友可以参考下
    2019-05-05
  • 基于vue-element组件实现音乐播放器功能

    基于vue-element组件实现音乐播放器功能

    这篇文章主要介绍了基于vue-element组件实现音乐播放器功能,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-05-05
  • 12 种使用Vue 的最佳做法

    12 种使用Vue 的最佳做法

    这篇文章主要介绍了12 种使用Vue 的最佳做法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Vue组件通信方法案例总结

    Vue组件通信方法案例总结

    这篇文章主要介绍了Vue组件通信方法案例总结,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • vue+express+jwt持久化登录的方法

    vue+express+jwt持久化登录的方法

    这篇文章主要介绍了vue+express+jwt持久化登录的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • vue与django(drf)实现文件上传下载功能全过程

    vue与django(drf)实现文件上传下载功能全过程

    最近简单的学习了django和drf上传文件(主要是图片),做一个记录,下面这篇文章主要给大家介绍了关于vue与django(drf)实现文件上传下载功能的相关资料,需要的朋友可以参考下
    2023-02-02
  • Vue页面跳转传递参数及接收方式

    Vue页面跳转传递参数及接收方式

    这篇文章主要介绍了Vue页面跳转传递参数及接收方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Vue使用高德地图实现城市定位

    Vue使用高德地图实现城市定位

    这篇文章主要为大家详细介绍了Vue使用高德地图实现城市定位,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • vuejs2.0运用原生js实现简单拖拽元素功能

    vuejs2.0运用原生js实现简单拖拽元素功能

    这篇文章主要为大家详细介绍了vuejs2.0运用原生js实现简单拖拽元素功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • Vue.js实现可编辑的表格

    Vue.js实现可编辑的表格

    这篇文章主要为大家详细介绍了Vue.js实现可编辑的表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12

最新评论