vuex學(xué)習(xí)筆記。

vuex理解覆积。

Vuex是一個(gè)專(zhuān)為Vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式听皿。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化宽档。

什么是“狀態(tài)管理模式”尉姨?

讓我們從一個(gè)簡(jiǎn)單的Vue計(jì)數(shù)應(yīng)用開(kāi)始:


這個(gè)狀態(tài)管理應(yīng)用包含以下幾個(gè)部分:

state,驅(qū)動(dòng)應(yīng)用的數(shù)據(jù)源。

view,以聲明的方式將state映射到視圖雌贱。

actions,響應(yīng)在view上的用戶(hù)輸入導(dǎo)致的狀態(tài)變化啊送。


單向數(shù)據(jù)流理念的極簡(jiǎn)示意圖

但是當(dāng)我們的應(yīng)用遇到多個(gè)組件共享狀態(tài)時(shí)偿短,單向數(shù)據(jù)流的簡(jiǎn)潔性很容易被破壞:

1.多個(gè)視圖依賴(lài)于同一個(gè)狀態(tài)。

2.來(lái)自不同視圖的行為需要變更同一狀態(tài)馋没。

對(duì)于問(wèn)題一昔逗,傳參的方法對(duì)于多層嵌套的組件將會(huì)非常的繁瑣,并且對(duì)于兄弟組件的狀態(tài)傳遞無(wú)能為力篷朵。

對(duì)于問(wèn)題二勾怒,我們經(jīng)常會(huì)采用父子組件直接引用或則通過(guò)事件變更和同步狀態(tài)的多份拷貝。

以上方法不利于代碼的維護(hù)声旺。

Vuex借鑒了Flux笔链,Redux,和The Elm Architecture.


1.引入vuex腮猖,利用npm包管理工具鉴扫,進(jìn)行安裝Vuex空繁。

npm install vuex --save

需要注意的是這里一定要加上--save装哆,因?yàn)檫@個(gè)包是在生產(chǎn)環(huán)境中使用的。

2.新建一個(gè)vuex文件夾侍瑟,并在文件夾下新建store.js文件姐赡,文件中引入我們的vue和vuex莱预。

01,import Vue from 'vue';

02项滑,import vuex from 'vuex';

3.使用vuex依沮,引入之后用Vue.use進(jìn)行引用。

Vue.use(vuex);

然后導(dǎo)出:

export default new vuex.Store({})

4.main.js文件中全局引用枪狂。

import store from ‘store.js文件路徑’;

new Vue ({

? ? store,

})

入門(mén)小demo

1.在store.js文件里增加一個(gè)常量對(duì)象危喉。

01寫(xiě)法:

const state = {

????count:1

}

export default new vuex.Store({

? ? state

})

02寫(xiě)法:

?export default new vuex.Store({

? ? state:{

? ? ? ? count:1

? ? }

})

2.新建一個(gè)vue模板,并在模板中使用{{$store.state.count}}輸出count的值。

3.在store.js文件中加入兩個(gè)改變state的方法摘完。

以第二種方法為例子:

mutations:{

? ? add(state){

? ? ? ? state.count++;

? ? }

? ? reduce(state){

? ? ? ? state.count--;

? ? }

}

4.在vue模板中加入兩個(gè)按鈕姥饰,并調(diào)用mutations中的方法。

實(shí)現(xiàn)vuex中的count加減

2.state訪問(wèn)狀態(tài)對(duì)象孝治。

把store.js中的狀態(tài)對(duì)象賦值給模板里data中的值列粪,有三種賦值方式。

1.通過(guò)computed的計(jì)算屬性直接賦值谈飒。

computed:{

? ? count(){

? ? ? ? return this.$store.state.count;

? ? }

}

2.通過(guò)mapState的對(duì)象來(lái)賦值岂座。

01,import {mapState} from 'vuex';

02杭措,computed:mapState(["count"]);當(dāng)映射的計(jì)算屬性的名稱(chēng)與 state 的子節(jié)點(diǎn)名稱(chēng)相同時(shí)费什,我們也可以給?mapState?傳一個(gè)字符串?dāng)?shù)組。

mapState的另一種用法:

mapState與局部計(jì)算屬性混用:

3.模板獲取Mutations方法手素。

更改Vuex的store中的狀態(tài)的唯一方法是提交mutaition鸳址。Vuex中的mutation非常類(lèi)似于事件:每個(gè)mutation都有一個(gè)字符串的事件類(lèi)型(type)和一個(gè)回調(diào)函數(shù)(handler)瘩蚪。這個(gè)回調(diào)函數(shù)就是我們實(shí)際進(jìn)行狀態(tài)更改的地方,并且它會(huì)接受state作為第一個(gè)參數(shù)稿黍。

mutation調(diào)用方法:

4.getter

有時(shí)我們需要從store中的state中派生出一些狀態(tài)疹瘦,例如對(duì)列表進(jìn)行過(guò)濾并計(jì)數(shù):

Getter接受state作為其第一個(gè)參數(shù),Getter會(huì)爆露為store.gettres對(duì)象巡球,你可以以屬性的形式訪問(wèn)這些值:

this.$store.getters.doneTodos;

Getter也可以接受其它getter作為第二個(gè)參數(shù):

我們可以很容易的在任何組件中使用它:

也可以通過(guò)方法訪問(wèn):你可以通過(guò)讓getter返回一個(gè)函數(shù)言沐,來(lái)實(shí)現(xiàn)給getter傳參。在你對(duì)store里的數(shù)組進(jìn)行查詢(xún)時(shí)非常有用酣栈。

mapGetters輔助函數(shù)

5.Action

action的作用跟mutation的作用是一致的险胰,它提交mutation從而改變state。

Action類(lèi)似于mutation矿筝,不同在于Action提交的是mutation起便,而不是直接更改狀態(tài)。Action可以包含任意異步操作跋涣。

注冊(cè)一個(gè)簡(jiǎn)單的action:

Action函數(shù)接受一個(gè)與store實(shí)例具有相同方法和屬性的context對(duì)象缨睡,因此可以調(diào)用context.commit提交一個(gè)mutation,或則通過(guò)context.state和context.getters來(lái)獲取state和getters陈辱。實(shí)踐中,我們經(jīng)常會(huì)使用ES2015的參數(shù)解構(gòu)來(lái)簡(jiǎn)化代碼细诸,特別是需要調(diào)用commit很多次的時(shí)候:

Action通過(guò)store.dispath方法觸發(fā):

Actions支持同樣的載荷方式和對(duì)象方式進(jìn)行分發(fā):

你在組件中使用?this.$store.dispatch('xxx')?分發(fā) action沛贪,或者使用?mapActions?輔助函數(shù)將組件的 methods 映射為?store.dispatch?調(diào)用(需要先在根節(jié)點(diǎn)注入?store):


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市震贵,隨后出現(xiàn)的幾起案子利赋,更是在濱河造成了極大的恐慌,老刑警劉巖猩系,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件媚送,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡寇甸,警方通過(guò)查閱死者的電腦和手機(jī)塘偎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)拿霉,“玉大人吟秩,你說(shuō)我怎么就攤上這事≌捞裕” “怎么了涵防?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)沪铭。 經(jīng)常有香客問(wèn)我壮池,道長(zhǎng)偏瓤,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任椰憋,我火速辦了婚禮厅克,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘熏矿。我一直安慰自己已骇,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布票编。 她就那樣靜靜地躺著褪储,像睡著了一般。 火紅的嫁衣襯著肌膚如雪慧域。 梳的紋絲不亂的頭發(fā)上鲤竹,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音昔榴,去河邊找鬼辛藻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛互订,可吹牛的內(nèi)容都是我干的吱肌。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼仰禽,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼氮墨!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起吐葵,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤规揪,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后温峭,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體猛铅,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年凤藏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了奸忽。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡清笨,死狀恐怖月杉,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情抠艾,我是刑警寧澤苛萎,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響腌歉,放射性物質(zhì)發(fā)生泄漏蛙酪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一翘盖、第九天 我趴在偏房一處隱蔽的房頂上張望桂塞。 院中可真熱鬧,春花似錦馍驯、人聲如沸阁危。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)狂打。三九已至,卻和暖如春混弥,著一層夾襖步出監(jiān)牢的瞬間趴乡,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工蝗拿, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留晾捏,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓哀托,卻偏偏與公主長(zhǎng)得像惦辛,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子仓手,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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

  • 安裝 npm npm install vuex --save 在一個(gè)模塊化的打包系統(tǒng)中裙品,您必須顯式地通過(guò)Vue.u...
    蕭玄辭閱讀 2,938評(píng)論 0 7
  • Vuex是什么? Vuex 是一個(gè)專(zhuān)為 Vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式俗或。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,120評(píng)論 0 6
  • Vuex 概念篇 Vuex 是什么? Vuex 是一個(gè)專(zhuān)為 Vue.js 應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式岁忘。它采用集中式...
    Junting閱讀 3,082評(píng)論 0 43
  • Vuex 是什么辛慰? Vuex 是一個(gè)專(zhuān)為 Vue.js 應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有...
    skycolor閱讀 837評(píng)論 0 1
  • vuex是一個(gè)狀態(tài)管理模式干像,通過(guò)用戶(hù)的actions觸發(fā)事件帅腌,然后通過(guò)mutations去更改數(shù)據(jù)(你也可以說(shuō)狀態(tài)...
    Ming_Hu閱讀 2,023評(píng)論 3 3