詳解vue組件化開發(fā)-vuex狀態(tài)管理庫
Vuex 是一個專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測的方式發(fā)生變化。Vuex 也集成到 Vue 的官方調(diào)試工具 devtools extension,提供了諸如零配置的 time-travel 調(diào)試、狀態(tài)快照導(dǎo)入導(dǎo)出等高級調(diào)試功能。
以上是vuex的官方文檔對vuex的介紹,官方文檔對vuex的用法進(jìn)行了詳細(xì)的說明。這里就不再細(xì)講vuex的各個用法,寫這篇博客的目的只是幫助部分同學(xué)更快地理解并上手vuex。
為什么要用vuex
不知道現(xiàn)在讀這篇博客的同學(xué)是否有看過Vue2.0子父組件之間通信,子父組件之間的基本通信方式。我們通信的目的往往就是在組件之間傳遞數(shù)據(jù)或組件的狀態(tài)(這里將數(shù)據(jù)和狀態(tài)統(tǒng)稱為狀態(tài)),進(jìn)而更改狀態(tài)。但可以看到如果我們通過最基本的方式來進(jìn)行通信,一旦需要管理的狀態(tài)多了,代碼就會變得十分混亂。對所有狀態(tài)的管理便會顯得力不從心,尤其是多人合作的時候。
此時vuex出現(xiàn)了,他就是幫助我們把公用的狀態(tài)全抽出來放在vuex的容器中,然后根據(jù)一定的規(guī)則來進(jìn)行管理
Vuex的核心
vuex由以下幾部分組成:
- state
- mutations
- getters
- actions
- modules
state里面就是存放項目中需要多組件共享的狀態(tài)
mutations就是存放更改state里狀態(tài)的方法
getters就是從state中派生出狀態(tài),比如將state中的某個狀態(tài)進(jìn)行過濾然后獲取新的狀態(tài)。
actions就是mutation的加強版,它可以通過commit mutations中的方法來改變狀態(tài),最重要的是它可以進(jìn)行異步操作。
modules顧名思義,就是當(dāng)用這個容器來裝這些狀態(tài)還是顯得混亂的時候,我們就可以把容器分成幾塊,把狀態(tài)和管理規(guī)則分類來裝。這和我們創(chuàng)建js模塊是一個目的,讓代碼結(jié)構(gòu)更清晰。
實例來理解Vuex
// 實例化vuex狀態(tài)庫
var vuexStore = new Vuex.Store({
state:{
message:'Hello World',
bookList:[
{
name:'javascript權(quán)威指南',
price:100,
en:'jq'
},
{
name:'angularjs權(quán)威指南',
price:80,
en:'aq'
},
{
name:'HTTP權(quán)威指南',
price:50,
en:'hq'
}
]
},
mutations:{
//同步
showMessage:function(state,data){
state.message = 'Store mutations changed this words。'+data;
}
addBook:function(state,data){
state.bookList.push(data)
}
},
getters:{
filterPrice:function(state){
var narr = [];
for(var i = 0;i<state.bookList.length;i++){
state.bookList[i].price<85 ? narr.push(state.bookList[i]) : null;
}
return narr;
}
},
actions:{
//異步操作
addBook:function(context){
setTimeout(function(){
context.commit('addBook',{name:'HTML5權(quán)威指南',price:75});
},2000);
}
},
modules:{
a:storeA,b:storeB
}
});
// vue 實例
var vm = new Vue({
el:'app',
store:VuexStore,
methods:{
showMessage:function(){
this.$store.commit('showMessage','荷載數(shù)據(jù)')
},
filterList:function(){
return this.store.getters.filterPrice();
},
addBooks:function(){
this.$store.dispatch('addBook')
},
}
});
【state】vuex核心概念有五個,試想當(dāng)我們把所有的狀態(tài)從各個組件抽出來,放入了state中:message和bookList;
【mutations】某個時候,某個組件中,我們需要把state中的message改變數(shù)據(jù),我們要通過調(diào)用commit方法提交到mutations對應(yīng)的事件:commit('showMessage'),這樣就會調(diào)用mutations里showMessage方法;調(diào)用方法是如上面代碼中57行的方式;
【getters】某個時間,某個組件我們需要獲得bookList中價格小于85的所有數(shù)據(jù),vuex中允許我們通過getters來獲?。菏褂梅椒ㄈ缟洗a中60行
【actions】這個是mutations的強化部分,只是這個里面的函數(shù)可以異步操作,比如網(wǎng)絡(luò)請求等等;這里面的方法如果要更改狀態(tài),最好要通過commit()函數(shù)提交到mutations里去處理。官方是這么說的。在實例里調(diào)用一般是通過dispatch('funName')來調(diào)用的;例如實例中:66行代碼
【關(guān)于moduls】modules其實就是多個狀態(tài)管理庫,放在一個對象里,比如我們有2個狀態(tài)庫:storeA,storeB。我們在modules里就和上面代碼中50行的寫法是一樣的。
在取值的時候就直接在實例里調(diào)用:this.$store.state.a即可返回storeA這個store里的狀態(tài)。
這里有一個點要注意一下:所有子模塊里的getters對象里的方法會被合并到$store里,如果不同子模塊里有重名的方法,那么會報錯;
但是所有子模塊里actions和mutations中的方法不會被合并,重名也不會報錯。但是當(dāng)你dispatch或者commit一個同名的事件的時候,會依次執(zhí)行每一個子模塊中的事件。
所以在不同子模塊的actions和mutations中不要寫重復(fù)的函數(shù)名稱;
使用Vuex
下面我們來講一下怎么引入一個Vuex協(xié)助我們管理狀態(tài):
首先當(dāng)然要引入Vuex.js;
然后,我們新建一個vuex實例
var store = new VuexStore({
state:{
} ,
mountations:{
},
})
創(chuàng)建好store后我們需要把這個store注入到vue的實例和組件中,
var vm = new Vue({
el:'#app',
store:store
})
然后我們就能像上面介紹的方法使用了。
最后多說一嘴,官方建議的目錄結(jié)構(gòu)是吧mutations,actions,getters等一系列,都分開放在不同的目錄,便于多人開發(fā)與維護(hù)。
vue到此已經(jīng)研究了很多。行百里者半九十,還需要深入研究。個人對vue2.0的總結(jié)demo已上傳至gitHub。地址:https://github.com/HUA1/vue2-summary.git
本文到此結(jié)束,所涉及的vue版本是2.0.x;vuex版本是:2.2.1。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue結(jié)合vant實現(xiàn)聯(lián)動效果
這篇文章主要為大家詳細(xì)介紹了vue結(jié)合vant實現(xiàn)聯(lián)動效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01
Vue 2.5.2下axios + express 本地請求404的解決方法
下面小編就為大家分享一篇Vue 2.5.2下axios + express 本地請求404的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02
vue項目創(chuàng)建并引入餓了么elementUI組件的步驟
這篇文章主要介紹了vue項目創(chuàng)建并引入餓了么elementUI組件的步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04
在vue-cli 3中給stylus、sass樣式傳入共享的全局變量
這篇文章主要介紹了在vue-cli 3中, 給stylus、sass樣式傳入共享的全局變量,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-08-08
關(guān)于vue3 vuex4 store的響應(yīng)式取值問題解決
這篇文章主要介紹了vue3 vuex4 store的響應(yīng)式取值問題,在實際生活中遇到這樣一個問題:在頁面中點擊按鈕,數(shù)量增加,值是存在store中的,點擊事件值沒變,如何解決這個問題,本文給大家分享解決方法,需要的朋友可以參考下2022-08-08
Vue3(ts)使用vee-validate表單校驗,自定義全局驗證規(guī)則說明
這篇文章主要介紹了Vue3(ts)使用vee-validate表單校驗,自定義全局驗證規(guī)則說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
vue+element_ui上傳文件,并傳遞額外參數(shù)操作
這篇文章主要介紹了vue+element_ui上傳文件,并傳遞額外參數(shù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12

