欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vuex的四個常用核心概念解讀

 更新時間:2024年11月08日 11:37:00   作者:帥氣的小蘇  
本文詳細解析了Vuex中的四個核心概念及其區(qū)別,包括State用于存儲狀態(tài),Getters用于計算屬性并緩存,Mutations是唯一更改State的同步方法,Actions則用于提交Mutations且支持異步操作

Vuex的四個常用核心概念

在 Vuex 中,state, getters、mutations 和 actions 是四個個核心概念,而同學們時常會搞亂其中的某些概念和用法, 這里統(tǒng)一講解一下

State

首先,我們要明確 Vuex 的核心概念 state。

State 是 Vuex 中用于存儲應用狀態(tài)的對象。

這些狀態(tài)是響應式的,當它們改變時,視圖會自動更新。

Getters

這里同學就有疑問了, vuex 的 state 明明可以直接進行訪問,為什么要畫蛇添足的加一個 Getters 呢?

其實: Getters 是用于從 state 中派生出一些狀態(tài),例如對 state 中的數據進行過濾或計算新的值。

與直接返回 state 的值相比,getter 的返回值會根據它的依賴進行緩存。

只有在相關依賴發(fā)生改變時才會重新求值。(說人話就是減少計算成本, 提高性能)

用法:

在 store 中定義 getter:

const store = new Vuex.Store ({  
  state: {  
    todos: [  
      { id: 1, text: '...', done: true },  
      { id: 2, text: '...', done: false }  
    ]  
  },  
  getters: {  
    doneTodos: state => {  
      return state.todos.filter (todo => todo. done)  
    }  
  }  
})

在組件中使用 getter:

computed: {  
  doneTodos () {  
    return this.$store. getters. doneTodos  
  }  
}

Mutations

Mutations 是 Vuex 中用于更改 state 的唯一方法( 記住, 是唯一的喲)。

Vuex 中的 mutations 非常類似于事件:每個 mutation 都有一個字符串的事件類型 (type) 和一個回調函數 (handler)。

這個回調函數就是我們實際進行狀態(tài)更改的地方,并且它會接受 state 作為第一個參數。

const store = new Vuex.Store ({  
  state: {  
    count: 0  
  },  
  mutations: {  
    increment (state) {  
      // 變更狀態(tài)  
      state.count++  
    }  
  }  
})
在組件中提交 mutation:

javascript
methods: {  
  increment () {  
    this.$store.commit ('increment')  
  }  
}

Actions

那么 actions 和 mutations 有什么區(qū)別呢?

Actions 類似于 mutations,不同在于:

  • Action 提交的是 mutation,而不是直接變更狀態(tài)。
  • Action 可以包含任意異步操作。
  • 當需要在 state 上執(zhí)行異步操作或者執(zhí)行一批 mutations 時,你可以使用 actions。

用法:

在 store 中定義 action:

const store = new Vuex.Store ({  
  state: {  
    count: 0  
  },  
  mutations: {  
    increment (state) {  
      state. count++  
    }  
  },  
  actions: {  
    incrementAsync ({ commit }) {  
      setTimeout (() => {  
        commit ('increment')  
      }, 1000)  
    }  
  }  
})

在組件中分發(fā) action:

methods: {  
  incrementAsync () {  
    this.$store.dispatch('incrementAsync')  
  }  
}

注意:

在 actions 中,你可以通過 context 對象來訪問 commit 方法(或其他 Vuex 屬性)。

為了方便,我們可以直接解構 commit 出來,就像上面的例子那樣。

總結

  • State:存儲應用的狀態(tài)。
  • Getters:基于 state 計算屬性,并可以緩存結果。
  • Mutations:直接更改 state 的唯一方式,且必須是同步函數。
  • Actions:類似于 mutations,用于提交 mutations,可以包含任意異步操作。

這四個概念共同構成了 Vuex 的核心功能,使得狀態(tài)管理在 Vue 應用中變得清晰、可預測和可維護。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 關于vue屬性使用和不使用冒號的區(qū)別說明

    關于vue屬性使用和不使用冒號的區(qū)別說明

    這篇文章主要介紹了關于vue屬性使用和不使用冒號的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • Vue.sync修飾符與$emit(update:xxx)詳解

    Vue.sync修飾符與$emit(update:xxx)詳解

    這篇文章主要介紹了Vue.sync修飾符與$emit(update:xxx),實現思路非常簡單,文章介紹了.sync修飾符的作用和使用.sync修飾符的寫法,實現代碼簡單易懂對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-11-11
  • Vue.js?前端路由和異步組件介紹

    Vue.js?前端路由和異步組件介紹

    這篇文章主要介紹了Vue.js?前端路由和異步組件介紹,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • 淺談vue的props,data,computed變化對組件更新的影響

    淺談vue的props,data,computed變化對組件更新的影響

    本篇文章主要介紹了淺談vue的props,data,computed變化對組件更新的影響,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • VSCode搭建Vue項目的方法

    VSCode搭建Vue項目的方法

    這篇文章主要介紹了VSCode搭建Vue項目的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • 可能是全網vue?v-model最詳細講解教程

    可能是全網vue?v-model最詳細講解教程

    Vue官網教程上關于v-model的講解不是十分的詳細,寫這篇文章的目的就是詳細的剖析一下,下面這篇文章主要給大家介紹了關于vue?v-model最詳細講解的相關資料,需要的朋友可以參考下
    2022-11-11
  • elementui中使用el-tabs切換實時更新數據

    elementui中使用el-tabs切換實時更新數據

    這篇文章主要介紹了elementui中使用el-tabs切換實時更新數據,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue導入excel文件的兩種方式(form表單和el-upload)

    Vue導入excel文件的兩種方式(form表單和el-upload)

    最近開發(fā)遇到一個點擊導入按鈕讓excel文件數據導入的需求,下面這篇文章主要給大家介紹了關于Vue導入excel文件的兩種方式,分別是form表單和el-upload兩種方法,需要的朋友可以參考下
    2022-11-11
  • Vue瀑布流插件的使用示例

    Vue瀑布流插件的使用示例

    這篇文章主要介紹了Vue瀑布流插件的使用示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • 深入理解Vue的過度與動畫

    深入理解Vue的過度與動畫

    這篇文章主要為大家介紹了Vue的過度與動畫,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11

最新評論