vuex

什么是Vuex

在Vue中饭豹,多組件的開發(fā)給我們帶來了很多的方便踪央,但同時當(dāng)項目規(guī)模變大的時候伞矩,多個組件間的數(shù)據(jù)通信和狀態(tài)管理就顯得難以維護(hù)。而Vuex就此應(yīng)運而生尽纽。將狀態(tài)管理單獨拎出來咐蚯,應(yīng)用統(tǒng)一的方式進(jìn)行處理,在后期維護(hù)的過程中數(shù)據(jù)的修改和維護(hù)就變得簡單而清晰了弄贿。Vuex采用和Redux類似的單向數(shù)據(jù)流的方式來管理數(shù)據(jù)春锋。用戶界面負(fù)責(zé)觸發(fā)動作(Action)進(jìn)而改變對應(yīng)狀態(tài)(State),從而反映到視圖(View)上差凹。如下圖所示:

安裝:

npm install --save vuex

引入:

import Vuex from 'vuex'import Vue from 'vue'Vue.use(Vuex)

Vuex的組成部分

完整的應(yīng)用Vuex開發(fā)的應(yīng)用結(jié)構(gòu)應(yīng)該是這樣的:


State

State負(fù)責(zé)存儲整個應(yīng)用的狀態(tài)數(shù)據(jù)期奔,一般需要在使用的時候在跟節(jié)點注入store
對象,后期就可以使用this.$store.state
直接獲取狀態(tài)
//store為實例化生成的import store from './store'new Vue({ el: '#app', store, render: h => h(App)})

這個store可以理解為一個容器危尿,包含著應(yīng)用中的state等呐萌。實例化生成store的過程是:
const mutations = {...};const actions = {...};const state = {...};Vuex.Store({ state, actions, mutation});

后續(xù)在組件中使用的過程中,如果想要獲取對應(yīng)的狀態(tài)你就可以直接使用this.$store.state
獲取谊娇,當(dāng)然肺孤,也可以利用vuex
提供的mapState
輔助函數(shù)將state
映射到計算屬性中去,如
//我是組件import {mapState} from 'vuex'export default { computed: mapState({ count: state => state.count })}

這樣直接就可以在組件中直接使用了济欢。

Mutations

Mutations的中文意思是“變化”渠旁,利用它可以更改狀態(tài),本質(zhì)就是用來處理數(shù)據(jù)的函數(shù)船逮,其接收唯一參數(shù)值state。

store.commit(mutationName)

是用來觸發(fā)一個mutation
的方法粤铭。需要記住的是挖胃,定義的mutation
必須是同步函數(shù),否則devtool中的數(shù)據(jù)將可能出現(xiàn)問題梆惯,使?fàn)顟B(tài)改變變得難以跟蹤酱鸭。

const mutations = { mutationName(state) { //在這里改變state中的數(shù)據(jù) }}

在組件中觸發(fā):
//我是一個組件export default { methods: { handleClick() { this.$store.commit('mutationName') } }}

或者使用輔助函數(shù)mapMutations
直接將觸發(fā)函數(shù)映射到methods
上,這樣就能在元素事件綁定上直接使用了垛吗。如:

import {mapMutations} from 'vuex'//我是一個組件export default { methods: mapMutations([ 'mutationName' ])}

Actions

Actions
也可以用于改變狀態(tài)凹髓,不過是通過觸發(fā)mutation
實現(xiàn)的,重要的是可以包含異步操作怯屉。其輔助函數(shù)是mapActions
與mapMutations
類似蔚舀,也是綁定在組件的methods
上的。如果選擇直接觸發(fā)的話锨络,使用this.$store.dispatch(actionName)
方法赌躺。
//定義Actionsconst actions = { actionName({ commit }) { //dosomething commit('mutationName') }}

在組件中使用

import {mapActions} from 'vuex'//我是一個組件export default { methods: mapActions([ 'actionName', ])}

Getters

有些狀態(tài)需要做二次處理,就可以使用getters
羡儿。通過this.$store.getters.valueName
對派生出來的狀態(tài)進(jìn)行訪問礼患。或者直接使用輔助函數(shù)mapGetters
將其映射到本地計算屬性中去。

const getters = { strLength: state => state.aString.length}//上面的代碼根據(jù)aString狀態(tài)派生出了一個strLength狀態(tài)

在組件中使用

import {mapGetters} from 'vuex'//我是一個組件export default { computed: mapGetters([ 'strLength' ])}

Plugins

插件就是一個鉤子函數(shù)缅叠,在初始化store
的時候引入即可悄泥。比較常用的是內(nèi)置的logger插件,用于作為調(diào)試使用肤粱。

import createLogger from 'vuex/dist/logger'const store = Vuex.Store({ ... plugins: [createLogger()]})

最后弹囚,還有一些高級用法,如嚴(yán)格模式狼犯,測試等可能使用頻率不會特別高余寥。有需要的時候查官方文檔就可以了∶跎總的來說宋舷,Vuex還是相對比較簡單的,特別是如果之前有學(xué)過Flux,Redux之類的話瓢姻,上手起來更加容易祝蝠。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市幻碱,隨后出現(xiàn)的幾起案子绎狭,更是在濱河造成了極大的恐慌,老刑警劉巖褥傍,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件儡嘶,死亡現(xiàn)場離奇詭異,居然都是意外死亡恍风,警方通過查閱死者的電腦和手機(jī)蹦狂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朋贬,“玉大人凯楔,你說我怎么就攤上這事〗跄迹” “怎么了摆屯?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長糠亩。 經(jīng)常有香客問我虐骑,道長,這世上最難降的妖魔是什么赎线? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任富弦,我火速辦了婚禮,結(jié)果婚禮上氛驮,老公的妹妹穿的比我還像新娘腕柜。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布盏缤。 她就那樣靜靜地躺著砰蠢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪唉铜。 梳的紋絲不亂的頭發(fā)上台舱,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天,我揣著相機(jī)與錄音潭流,去河邊找鬼竞惋。 笑死,一個胖子當(dāng)著我的面吹牛灰嫉,可吹牛的內(nèi)容都是我干的拆宛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼讼撒,長吁一口氣:“原來是場噩夢啊……” “哼浑厚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起根盒,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤钳幅,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后炎滞,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體敢艰,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年册赛,在試婚紗的時候發(fā)現(xiàn)自己被綠了钠导。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡击奶,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出责掏,到底是詐尸還是另有隱情柜砾,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布换衬,位于F島的核電站痰驱,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏瞳浦。R本人自食惡果不足惜担映,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望叫潦。 院中可真熱鬧蝇完,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至朋魔,卻和暖如春岖研,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背警检。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工孙援, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人扇雕。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓拓售,卻偏偏與公主長得像,于是被迫代替她去往敵國和親洼裤。 傳聞我的和親對象是個殘疾皇子邻辉,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內(nèi)容

  • Vuex是什么? Vuex 是一個專為 Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式腮鞍。它采用集中式存儲管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,122評論 0 6
  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統(tǒng)中值骇,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,945評論 0 7
  • 這兩天在做Vue移動端的項目,正好用到了Vuex移国,記錄一下相關(guān)知識吱瘩。 一、安裝 npm yarn Vuex是Vue...
    婷樓沐熙閱讀 7,691評論 2 2
  • Vuex 的學(xué)習(xí)記錄 資料參考網(wǎng)址Vuex中文官網(wǎng)Vuex項目結(jié)構(gòu)示例 -- 購物車Vuex 通俗版教程Nuxt....
    流云012閱讀 1,462評論 0 7
  • vuex是什么鬼迹缀? 如果你用過redux就能很快的理解vuex是個什么鬼東西了使碾。他是vuejs用來管理狀態(tài)的插件。...
    麥子_FE閱讀 6,870評論 3 37