91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vuex中action何時完成以及怎么正確調用dispatch

發布時間:2021-02-08 10:42:22 來源:億速云 閱讀:286 作者:小新 欄目:web開發

這篇文章主要介紹vuex中action何時完成以及怎么正確調用dispatch,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

問題1:如果action是異步的,那么怎么知道它什么時候完成?在vuex的官網給出了答案:

vuex中action何時完成以及怎么正確調用dispatch

注:如果需要通過組合多個action來完成某些邏輯,用async/await會更簡單一點

問題2: 如果action是同步的,就不需要等待它完成了嗎?

其實這個問題相當于在w:dispatch('some action')是一個同步函數還是異步函數。

如果dispatch是一個異步函數(返回一個promise),那么即使action里面的邏輯是同步的,如果需要等待這個action完成之后才進行某些操作,仍然是需要用異步等待dispatch().then(()=> {})來實現

通過查看vuex的源碼找到了答案:

 dispatch (_type, _payload) {
  // check object-style dispatch
  const {
   type,
   payload
  } = unifyObjectStyle(_type, _payload)

  const action = { type, payload }
  const entry = this._actions[type]
  if (!entry) {
   if (process.env.NODE_ENV !== 'production') {
    console.error(`[vuex] unknown action type: ${type}`)
   }
   return
  }

  try {
   this._actionSubscribers
    .filter(sub => sub.before)
    .forEach(sub => sub.before(action, this.state))
  } catch (e) {
   if (process.env.NODE_ENV !== 'production') {
    console.warn(`[vuex] error in before action subscribers: `)
    console.error(e)
   }
  }

  const result = entry.length > 1
   ? Promise.all(entry.map(handler => handler(payload)))
   : entry[0](payload)

  return result.then(res => {
   try {
    this._actionSubscribers
     .filter(sub => sub.after)
     .forEach(sub => sub.after(action, this.state))
   } catch (e) {
    if (process.env.NODE_ENV !== 'production') {
     console.warn(`[vuex] error in after action subscribers: `)
     console.error(e)
    }
   }
   return res
  })
 }

dispatch函數返回的是一個promise,所以dispatch后如果需要跟進操作(比如dispatch里面commit了一個state,后續要用到這個state),正確的做法應該是需要用異步的方式來完成后續的邏輯

注:用同步的寫法看起來好像state也是對的,但可能只是恰好我的業務場景io使用不是很高所以"看起來是對的",嚴謹的做法應該還是需要用異步來完成后續操作的

以上是“vuex中action何時完成以及怎么正確調用dispatch”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

凤台县| 靖西县| 和顺县| 偏关县| 永州市| 横峰县| 柘荣县| 旌德县| 和平区| 鹤庆县| 鹰潭市| 苗栗县| 正安县| 达拉特旗| 榆中县| 家居| 公主岭市| 合作市| 铅山县| 蒲城县| 洪泽县| 南川市| 静乐县| 曲沃县| 海原县| 普兰店市| 石渠县| 灵台县| 宜川县| 和田市| 长顺县| 和政县| 双峰县| 洛阳市| 安吉县| 太和县| 石柱| 平塘县| 江西省| 呼图壁县| 自治县|