亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue關于Promise的使用方式

 更新時間:2024年06月18日 09:09:25   作者:曾令勝  
這篇文章主要介紹了vue關于Promise的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

Promise基本概念

Promise是一個構造函數,所以可以 new 出一個Promise的實例;

  • 在Promise上有兩個函數 resolve (成功之后的回調函數)和 reject (失敗后的回調函數);
  • 在Promise構造函數的prototype屬性上,有一個 .then() 方法。

所以只要是Promise構造函數創(chuàng)建的實例,都可以訪問到 .then()方法;

  • Promise表示一個一步操作,每當我們new一個Promise的實例,這個實例就代表具體的 異步 操作。
  • Promise創(chuàng)建的實例,是一個異步操作,這個異步操作結果,

只有兩種結果:

  • 狀態(tài)1:異步執(zhí)行 成功,需要在內部調用成功的回調函數resolve把結果返回給調用者
  • 狀態(tài)2:異步執(zhí)行 失敗,需要在內部調用失敗的回調函數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 才會觸發(fā) 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

最新評論