this.$store.dispatch的全面解析

一、基礎概念

1、this.$store.dispatch是VueX框架中用來觸發actions的方法

2、actions是一個用於提交mutations的方法的對象集合,它可以包含任意非同步操作

3、mutations是一個用於改變state狀態的方法的對象集合,它只能包含同步操作

4、state是一個用來存儲數據狀態的集合

5、使用dispatch方法需要在Vue組件中先引入VueX的store文件

import store from './store'

export default {
   mounted() {
      console.log(this.$store) //undefined
      console.log(store) // store對象
   }
}

二、dispatch方法的使用

1、基礎用法:通過store.dispatch方法傳入actions名稱來觸發actions中的方法

export default {
   methods: {
      async fetchData() {
         const data = await this.$store.dispatch('fetchDataAction')
         console.log(data)
      }
   }
}

2、傳參用法:如果actions中定義了參數,可以在store.dispatch()中傳入參數

store.dispatch('fetchDataAction', params)

3、Promise用法:store.dispatch()返回一個promise對象,可以通過.then()訪問actions中直接返回的數據

store.dispatch('fetchDataAction').then(data => {
    console.log(data)
})

4、async/await用法:可以直接使用async/await語法獲取非同步操作返回的結果

async function() {
   const data = await store.dispatch('fetchDataAction')
   console.log(data)
}

三、dispatch方法的參數

1、第一個參數:actions名稱,必填項

2、第二個參數:actions操作的參數,可選項

3、第三個參數:具有多個觸發mutations的actions執行器數據,必須為對象格式,可選項

4、第四個參數:觸發成功時的回調函數,可選項

5、第五個參數:觸發失敗時的回調函數,可選項

store.dispatch('actionName', {
   parameter1: value1,
   parameter2: value2
}, {
   root: true,
   test: () => console.log('test')
}, 
() => {
   console.log('success')
},
() => {
   console.log('fail')
})

四、常見應用場景

1、非同步請求數據到組件中渲染頁面

// action.js
export const fetchDataAction = async ({ commit }) => {
  const data = await api.fetchData()
  commit('setFetchedData', data)
  
  return data
}
// mutation.js
export default {
  setFetchedData (state, data) {
    state.data = data
  }
}
// component.vue
async created () {
  await this.$store.dispatch('fetchDataAction')
  console.log(this.$store.state.data)
}

2、調用其他mutation來執行多個非同步操作

// action.js
export const fetchDataAction = async ({ commit }) => {
   const data = await api.fetchData()
   commit('setData', data)
   return data
}
export const filterDataAction = async ({ commit }, filterValue) => {
   const filteredData = await api.filterData(filterValue)
   commit('setFilteredData', filteredData)
}
export const fetchAndFilterDataAction = async dispatch => {
   await dispatch('fetchDataAction')
   await dispatch('filterDataAction', 'filter')
}
// mutation.js
export default {
   setData (state, data) {
      state.data = data
   },
   setFilteredData (state, filteredData) {
      state.filteredData = filteredData
   }
}
// component.vue
async created () {
  await this.$store.dispatch('fetchAndFilterDataAction')
  console.log(this.$store.state.data)
  console.log(this.$store.state.filteredData)
}

3、使用commit方法提交多個mutation

// action.js
export const fetchDataAction = async ({ commit }) => {
   const data = await api.fetchData()
   commit('setData1', data)
   commit({
      type: 'setData2',
      data: 'data2'
   })
}
// mutation.js
export default {
   setData1 (state, data) {
      state.data1 = data
   },
   setData2 (state, data) {
      state.data2 = data
   }
}
// component.vue
async created () {
  await this.$store.dispatch('fetchDataAction')
  console.log(this.$store.state.data1)
  console.log(this.$store.state.data2)
}

五、總結

通過以上的介紹,我們可以了解到this.$store.dispatch是用來觸發actions的方法,具有傳參、Promise、async/await用法,支持多個觸發mutations的actions執行器數據和成功、失敗回調函數。同時我們也能看到this.$store.dispatch廣泛用於非同步請求數據到組件中渲染頁面、調用其他mutation來執行多個非同步操作、使用commit方法提交多個mutation等方面,是VueX框架中非常重要的一個方法。

原創文章,作者:SZWYK,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/324699.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
SZWYK的頭像SZWYK
上一篇 2025-01-13 13:23
下一篇 2025-01-13 13:23

相關推薦

  • Python應用程序的全面指南

    Python是一種功能強大而簡單易學的編程語言,適用於多種應用場景。本篇文章將從多個方面介紹Python如何應用於開發應用程序。 一、Web應用程序 目前,基於Python的Web…

    編程 2025-04-29
  • Python zscore函數全面解析

    本文將介紹什麼是zscore函數,它在數據分析中的作用以及如何使用Python實現zscore函數,為讀者提供全面的指導。 一、zscore函數的概念 zscore函數是一種用於標…

    編程 2025-04-29
  • 全面解讀數據屬性r/w

    數據屬性r/w是指數據屬性的可讀/可寫性,它在程序設計中扮演著非常重要的角色。下面我們從多個方面對數據屬性r/w進行詳細的闡述。 一、r/w的概念 數據屬性r/w即指數據屬性的可讀…

    編程 2025-04-29
  • Python計算機程序代碼全面介紹

    本文將從多個方面對Python計算機程序代碼進行詳細介紹,包括基礎語法、數據類型、控制語句、函數、模塊及面向對象編程等。 一、基礎語法 Python是一種解釋型、面向對象、動態數據…

    編程 2025-04-29
  • Matlab二值圖像全面解析

    本文將全面介紹Matlab二值圖像的相關知識,包括二值圖像的基本原理、如何對二值圖像進行處理、如何從二值圖像中提取信息等等。通過本文的學習,你將能夠掌握Matlab二值圖像的基本操…

    編程 2025-04-28
  • 瘋狂Python講義的全面掌握與實踐

    本文將從多個方面對瘋狂Python講義進行詳細的闡述,幫助讀者全面了解Python編程,掌握瘋狂Python講義的實現方法。 一、Python基礎語法 Python基礎語法是學習P…

    編程 2025-04-28
  • 全面解析Python中的Variable

    Variable是Python中常見的一個概念,是我們在編程中經常用到的一個變數類型。Python是一門強類型語言,即每個變數都有一個對應的類型,不能無限制地進行類型間轉換。在本篇…

    編程 2025-04-28
  • Zookeeper ACL 用戶 anyone 全面解析

    本文將從以下幾個方面對Zookeeper ACL中的用戶anyone進行全面的解析,並為讀者提供相關的示例代碼。 一、anyone 的作用是什麼? 在Zookeeper中,anyo…

    編程 2025-04-28
  • Switchlight的全面解析

    Switchlight是一個高效的輕量級Web框架,為開發者提供了簡單易用的API和豐富的工具,可以快速構建Web應用程序。在本文中,我們將從多個方面闡述Switchlight的特…

    編程 2025-04-28
  • Python合集符號全面解析

    Python是一門非常流行的編程語言,在其語法中有一些特殊的符號被稱作合集符號,這些符號在Python中起到非常重要的作用。本文將從多個方面對Python合集符號進行詳細闡述,幫助…

    編程 2025-04-28

發表回復

登錄後才能評論