vue store之狀態管理模式


狀態管理

 

一、狀態管理(vuex)簡介

  vuex是專為vue.js應用程序開發的狀態管理模式。它采用集中存儲管理應用的所有組件的狀態,並以相應的規則保證狀態以一種可預測的方式發生變化。vuex也集成到vue的官方調試工具devtools extension,提供了諸如零配置的time-travel調試、狀態快照導入導出等高級調試功能。

Vuex 的思想

  當我們在頁面上點擊一個按鈕,它會處發(dispatch)一個action, action 隨后會執行(commit)一個mutation, mutation 立即會改變state, state 改變以后,我們的頁面會state 獲取數據,頁面發生了變化。 Store 對象,包含了我們談到的所有內容,action, state, mutation,所以是核心了
官方demo

 1 const store = new Vuex.Store({
 2   state: {
 3     count: 0
 4   },
 5   mutations: {
 6     increment (state) {
 7       state.count++
 8     }
 9   }
10 })

二、狀態管理核心狀態管理有5個核心,分別是state、getter、mutation、action以及module。

分別簡單的介紹一下他們:

1、state

  state為單一狀態樹,在state中需要定義我們所需要管理的數組、對象、字符串等等,只有在這里定義了,在vue.js的組件中才能獲取你定義的這個對象的狀態。

2、getter

  getter有點類似vue.js的計算屬性,當我們需要從store的state中派生出一些狀態,那么我們就需要使用getter,getter會接收state作為第一個參數,而且getter的返回值會根據它的依賴被緩存起來,只有getter中的依賴值(state中的某個需要派生狀態的值)發生改變的時候才會被重新計算。

3、mutation

  更改store中state狀態的唯一方法就是提交mutation,就很類似事件。每個mutation都有一個字符串類型的事件類型和一個回調函數,我們需要改變state的值就要在回調函數中改變。我們要執行這個回調函數,那么我們需要執行一個相應的調用方法:store.commit。

4、action

  action可以提交mutation,在action中可以執行store.commit,而且action中可以有任何的異步操作。在頁面中如果我們要嗲用這個action,則需要執行store.dispatch5、module module其實只是解決了當state中很復雜臃腫的時候,module可以將store分割成模塊,每個模塊中擁有自己的state、mutation、action和getter。

簡單的 store 模式

 1 var store = {
 2   debug: true,
 3   state: {
 4     message: 'Hello!'
 5   },
 6   setMessageAction (newValue) {
 7     if (this.debug) console.log('setMessageAction triggered with', newValue)
 8     this.state.message = newValue
 9   },
10   clearMessageAction () {
11     if (this.debug) console.log('clearMessageAction triggered')
12     this.state.message = ''
13   }
14 }

  所有 store 中 state 的改變,都放置在 store 自身的 action 中去管理。這種集中式狀態管理能夠被更容易地理解哪種類型的 mutation 將會發生,以及它們是如何被觸發。當錯誤出現時,我們現在也會有一個 log 記錄 bug 之前發生了什么。

  此外,每個實例/組件仍然可以擁有和管理自己的私有狀態:

 1 var vmA = new Vue({
 2   data: {
 3     privateState: {},
 4     sharedState: store.state
 5   }
 6 })
 7 
 8 var vmB = new Vue({
 9   data: {
10     privateState: {},
11     sharedState: store.state
12   }
13 })

三.在項目中使用

1.store文件夾一般有以下6個文件。

2.在文件中引入:(新建一個store文件夾,在文件夾下的index.js文件進行如下編寫)

1 import Vue from 'vue'
2 import Vuex from 'vuex'
3 import createPersistedState from 'vuex-persistedstate'
4 Vue.use(Vuex)

 

3.定義簡單模塊:

 1 const module = {
 2     state: {
 3         user: {
 4             name: 'rookie'
 5         }
 6     },
 7     getters: {},
 8     mutations: {
 9         setUser(state, payload){
10             if(payload.hasOwnProperty('name')){
11                 state.user.name = payload.name
12             }
13         }
14     },
15     plugins: [createPersistedState()]
16 }

 

上面是一個簡單的vuex,在vuex中對應的store應用,在store中包含組件的共享狀態state和改變狀態的方法(暫且稱作方法)mutations。注意state相當於對外的只讀狀態,不能通過store.state.user.name來更改,使用store.commit方法通過觸發mutations改變state。
在頁面中獲取記錄的值name為rookie:

1 mounted(){
2     console.log(this.$store.state.user.name);
3 }

store.state為獲取store中的值,此時在my頁面中打印出來的值為rookie,而我們想要修改name的值,則需要借助store.commit方法來觸發mutations:

this.$store.commit('setUser',{name: 'kuke_kuke'})

在mutations中找到setUser,第二個參數payload為傳入的對象{name: ‘kuke_kuke’},調用方法hadOwnProperty來判斷傳入的對象是否有name屬性,從而修改state中的值,此時在頁面中再次打印user.name的值為’kuke _ kuke’。
最后導出模塊:

const store = new Vuex.Store(module)
export default store

在main.js中獲取模塊並使用:

import store from './store'
new Vue({
    store
})

 

原文鏈接:https://blog.csdn.net/qq_38658567/article/details/82847758


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM