vue.js的狀態管理vuex中store的使用
一、狀態管理(vuex)簡介
vuex是專為vue.js應用程式開發的狀態管理模式。它採用集中儲存管理應用的所有元件的狀態,並以相應的規則保證狀態以一種可預測的方式發生變化。vuex也整合刀vue的官方除錯工具devtools extension,提供了諸如零配置的time-travel除錯、狀態快照匯入匯出等高階除錯功能。
二、狀態管理核心
狀態管理有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.dispatch
5、module
module其實只是解決了當state中很複雜臃腫的時候,module可以將store分割成模組,每個模組中擁有自己的state、mutation、action和getter。
三、例項
首先建立一個vue.js專案,然後引入vuex
npm install vuex --save
而後建立一個store資料夾,建立一個store.js。在store.js中引入vue和vuex、在有需要的時候可以引入axios。
import vue from 'vue'
import vuex from 'vuex'
vue.use(vuex)
const state={
userList:[]
}
const mutations={
setUserList(state,data){
state.userList=data;
(注:如果這裡的userList需要axios請求也可以把axios寫在等號後面)
}
}
const action={
commitUserList:({commit},userList)=>commit('setUserList',userList)
}
這樣一個簡單的store.js就已經完成了。
在介面中我們要怎麼使用這個建立的狀態管理呢:
首先在script下引入store.js
<script>
import store from 'store.js的路徑'
data(){
return{
userList:store.state.userList;//引入state中的物件
}
},
methods:{
useAction(){
var item=['1':'2','a':'c'];
store.dispatch('setUserList',item);
}
}
</script>