1. 程式人生 > >vue store之狀態管理模式

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

const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    }
  }
})

二、狀態管理核心狀態管理有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 模式

var store = {
  debug: true,
  state: {
    message: 'Hello!'
  },
  setMessageAction (newValue) {
    if (this.debug) console.log('setMessageAction triggered with', newValue)
    this.state.message = newValue
  },
  clearMessageAction () {
    if (this.debug) console.log('clearMessageAction triggered')
    this.state.message = ''
  }
}

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

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

var vmA = new Vue({
  data: {
    privateState: {},
    sharedState: store.state
  }
})

var vmB = new Vue({
  data: {
    privateState: {},
    sharedState: store.state
  }
})

在這裡插入圖片描述

三.在專案中使用
1.store資料夾一般有以下6個檔案。
在這裡插入圖片描述

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

import Vue from 'vue'
import Vuex from 'vuex'
import createPersistedState from 'vuex-persistedstate'
Vue.use(Vuex)

3.定義簡單模組:

const module = {
    state: {
        user: {
            name: 'rookie'
        }
    },
    getters: {},
    mutations: {
        setUser(state, payload){
            if(payload.hasOwnProperty('name')){
                state.user.name = payload.name
            }
        }
    },
    plugins: [createPersistedState()]
}

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

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

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
})