在vue-cli項(xiàng)目里使用vuex,vuex的詳細(xì)使用

之前寫(xiě)過(guò)很多vue項(xiàng)目,項(xiàng)目中使用過(guò)vuex稚补,那個(gè)時(shí)候看vuex愣是云里霧里童叠,都是照葫蘆畫(huà)瓢使用,沒(méi)有清楚弄明白孔厉,

今天再看一下文檔,感覺(jué)茅塞頓開(kāi)帖努,特別寫(xiě)下來(lái)撰豺,給需要的人借鑒

一,什么是vuex

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

官方文檔是這么說(shuō)的匙监,反正我是沒(méi)看明白

以自己的話說(shuō)vuex是一個(gè)把多個(gè)組件通用的數(shù)據(jù)我們把它拿出來(lái)凡橱,放到一個(gè)叫store里面管理小作,在需要使用的組件里,我們可以拿出來(lái)使用

簡(jiǎn)單來(lái)說(shuō)就是data的共享屬性

二稼钩,關(guān)于store

“store”基本上就是一個(gè)容器顾稀,它包含著你的應(yīng)用中大部分的狀態(tài) (state)。

暫時(shí)先把state當(dāng)成我們通用data來(lái)看吧坝撑,這樣就好理解咯~

三静秆,關(guān)于State

state就是我們項(xiàng)目全局通用的data屬性,并且這些屬性是響應(yīng)式的巡李,也就是說(shuō)當(dāng)屬性發(fā)生改變時(shí)抚笔,state是會(huì)動(dòng)態(tài)響應(yīng)的

四,關(guān)于Getter

Getter可以使我們需要從 store 中的 state 中派生出一些狀態(tài)侨拦,例如對(duì)列表進(jìn)行過(guò)濾并計(jì)數(shù)等

Vuex 允許我們?cè)?store 中定義“getter”(可以認(rèn)為是 store 的計(jì)算屬性)殊橙。就像計(jì)算屬性一樣,

getter 的返回值會(huì)根據(jù)它的依賴被緩存起來(lái)狱从,且只有當(dāng)它的依賴值發(fā)生了改變才會(huì)被重新計(jì)算膨蛮。

五,關(guān)于Mutation

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

五训貌,關(guān)于Action

Action 類似于 mutation制肮,不同在于 (劃重點(diǎn)哦,很多面試官會(huì)問(wèn)噠~) :

1递沪, 提交的是 mutation豺鼻,而不是直接變更狀態(tài)。

2款慨, 可以包含任意異步操作儒飒。

六,關(guān)于Module

由于使用單一狀態(tài)樹(shù)檩奠,應(yīng)用的所有狀態(tài)會(huì)集中到一個(gè)比較大的對(duì)象桩了。當(dāng)應(yīng)用變得非常復(fù)雜時(shí),store 對(duì)象就有可能變得相當(dāng)臃腫埠戳。為了解決以上問(wèn)題井誉,Vuex 允許我們將 store 分割成模塊(module)。每個(gè)模塊擁有自己的 state整胃、mutation颗圣、action、getter、甚至是嵌套子模塊——從上至下進(jìn)行同樣方式的分割

七在岂,如何使用

我們講了那么多理論知識(shí)奔则,那實(shí)際情況我們?nèi)绾问褂媚兀黄饋?lái)看吧:

首先是安裝

(1)npm install vuex --save

(2)新建倉(cāng)庫(kù)

在src目錄下新建一個(gè)文件夾蔽午,我們命名為store好了易茬,然后在該文件夾下面創(chuàng)建一個(gè)js文件,我們還是叫他store好啦,截圖看起來(lái)更方便哦


然后開(kāi)始在main.js引入

安裝和引入都好了祠丝,我們來(lái)玩玩吧

在剛剛建的store文件里

import Vue from 'vue'

import Vuex from 'vuex'

Vue.use(Vuex)


我們存兩個(gè)變量來(lái)看看

找個(gè)頁(yè)面疾呻,在creat里打印一下this

creat(){

console.log(this)

}


嗯,找到我們剛剛創(chuàng)建的倉(cāng)庫(kù)啦

來(lái)看看倉(cāng)庫(kù)里面有什么吧


看到我們定義的state和mutation咯

那我們?cè)趺茨玫綌?shù)據(jù)呢写半?

我們都可以打印出來(lái)岸蜗,聰明的你應(yīng)該不會(huì)被難倒吧

1,舉個(gè)例子 我們來(lái)拿state的name吧

creat(){

console.log(this.$store.state.name)

}


看叠蝇,數(shù)據(jù)打印出來(lái)啦璃岳,是不是超級(jí)簡(jiǎn)單

數(shù)據(jù)拿到了,我想改變他怎么辦悔捶?別擔(dān)心铃慷,我們有mutation


這是我們之前定義的方法

在其他頁(yè)面我們寫(xiě)個(gè)function吧


然后在data里定義msg的值吧


然后我們調(diào)用changeName


看到了嗎 我們的數(shù)據(jù)改變咯

這里只是簡(jiǎn)單介紹了vuex,帶領(lǐng)大家入門(mén),詳細(xì)的還是去擼官方文檔吧蜕该,再見(jiàn)~

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末氧枣,一起剝皮案震驚了整個(gè)濱河市脖卖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖预吆,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件年扩,死亡現(xiàn)場(chǎng)離奇詭異待侵,居然都是意外死亡胶滋,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)皆的,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)覆履,“玉大人,你說(shuō)我怎么就攤上這事费薄∠跞” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵楞抡,是天一觀的道長(zhǎng)伟众。 經(jīng)常有香客問(wèn)我,道長(zhǎng)拌倍,這世上最難降的妖魔是什么赂鲤? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮柱恤,結(jié)果婚禮上数初,老公的妹妹穿的比我還像新娘。我一直安慰自己梗顺,他們只是感情好泡孩,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著寺谤,像睡著了一般仑鸥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上变屁,一...
    開(kāi)封第一講書(shū)人閱讀 49,007評(píng)論 1 284
  • 那天眼俊,我揣著相機(jī)與錄音,去河邊找鬼粟关。 笑死疮胖,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的闷板。 我是一名探鬼主播澎灸,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼遮晚!你這毒婦竟也來(lái)了性昭?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤县遣,失蹤者是張志新(化名)和其女友劉穎糜颠,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體艺玲,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡括蝠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了饭聚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片忌警。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖秒梳,靈堂內(nèi)的尸體忽然破棺而出法绵,到底是詐尸還是另有隱情,我是刑警寧澤酪碘,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布朋譬,位于F島的核電站,受9級(jí)特大地震影響兴垦,放射性物質(zhì)發(fā)生泄漏徙赢。R本人自食惡果不足惜字柠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望狡赐。 院中可真熱鬧窑业,春花似錦、人聲如沸枕屉。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)搀擂。三九已至西潘,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間哨颂,已是汗流浹背喷市。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留威恼,地道東北人东抹。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像沃测,于是被迫代替她去往敵國(guó)和親缭黔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

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

  • 安裝 npm npm install vuex --save 在一個(gè)模塊化的打包系統(tǒng)中蒂破,您必須顯式地通過(guò)Vue.u...
    蕭玄辭閱讀 2,926評(píng)論 0 7
  • 系列文章:Vue 2.0 升(cai)級(jí)(keng)之旅Vuex — The core of Vue applic...
    6ed7563919d4閱讀 4,541評(píng)論 2 58
  • Vuex是什么馏谨? Vuex 是一個(gè)專為 Vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,106評(píng)論 0 6
  • vuex是一個(gè)狀態(tài)管理模式附迷,通過(guò)用戶的actions觸發(fā)事件惧互,然后通過(guò)mutations去更改數(shù)據(jù)(你也可以說(shuō)狀態(tài)...
    Ming_Hu閱讀 2,016評(píng)論 3 3
  • vuex 場(chǎng)景重現(xiàn):一個(gè)用戶在注冊(cè)頁(yè)面注冊(cè)了手機(jī)號(hào)碼,跳轉(zhuǎn)到登錄頁(yè)面也想拿到這個(gè)手機(jī)號(hào)碼喇伯,你可以通過(guò)vue的組件化...
    sunny519111閱讀 8,008評(píng)論 4 111