Vuex的一些知識點

vuex的一些知識點

vuex是vue的狀態(tài)管理工具通過安裝

npm install vuex --save

vuex是一個專為vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式,采用集中式存儲管理應(yīng)用的所有組件的狀態(tài)墓懂,并以相應(yīng)的規(guī)則保證以一種可預(yù)測的方式發(fā)生變化踪少,類似于本地存儲
store是每一個vuex應(yīng)用的核心就是store(倉庫)基本可以想象為一個容器外驱,它包含著你的應(yīng)用中大部分的狀態(tài)贱鄙,vuex和單純的全局對象有以下兩點不同

  1. vuex的狀態(tài)存儲是響應(yīng)式的翁都,當(dāng)vue組件從store中讀取的狀態(tài),若store中的狀態(tài)發(fā)生變化寒砖,那么相應(yīng)的組件也會相應(yīng)的得到高效更新
  2. 你不能直接改變store中的狀態(tài),改變store中的狀態(tài)唯一途徑就是顯式的提交mutation嫉拐,這樣使得我們可以方便的追蹤每一個狀態(tài)的變化哩都,從而讓我們實現(xiàn)一些工具幫助我們更好的理解我們的應(yīng)用

state

Vuex通過store選項,提供了一種機制將狀態(tài)從根組件“注入”到每一個子組件(調(diào)用Vue.use(Vuex))
使用腳手架搭建起來項目后在main.js中引入Vuex

import Vue from 'vue'
import App from './App'
// import router from './router'
import store from './vuex/store'

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  // router,
    store,
  components: { App },
  template: '<App/>'
})

通過在根實例中注冊store選項婉徘,該store實例會注入到根組件下的所有子組件中漠嵌,且子組件能通過this.$store訪問到

const Counter = {
  template: `<div>{{ count }}</div>`,
  computed: {
    count () {
      return this.$store.state.count
    }
  }
}

更改vuex的store中的狀態(tài)的唯一方法是提交mutation Vuex中的mutation都有一個字符串中的事件類型和一個回調(diào)函數(shù),這個回調(diào)函數(shù)就是我們實際進(jìn)行狀態(tài)改變的地方盖呼,并且他會接受state作為第一個參數(shù)

const store = new Vuex.Store({
  state: {
    count: 1
  },
  mutations: {
    increment (state) {
      // 變更狀態(tài)
      state.count++
    }
  }
})

不能直接調(diào)用mutations handler儒鹿,這個選項更像是事件注冊:“當(dāng)觸發(fā)一個類型為increment”的mutation時,是要使用

store.commit('increment')

提交載荷
可以向store.commit傳入額外的參數(shù)几晤,即mutation 的載荷

// ...
mutations: {
  increment (state, n) {
    state.count += n
  }
}
store.commit('increment', 10)

在大多數(shù)情況下约炎,載荷應(yīng)該是一個對象,這樣可以包含多個字段并且記錄的 mutation 會更易讀:

// ...
mutations: {
  increment (state, payload) {
    state.count += payload.amount
  }
}
store.commit('increment', {
  amount: 10
})


對象風(fēng)格的提交方式

store.commit({
  type: 'increment',
  amount: 10
})

Action

Action類似于mutation 不同在于

  • Action 提交的時mutation 而不是直接變更狀態(tài)
  • Action可以包含任意異步操作
    注冊一個簡單的aciton
    讓我們來注冊一個簡單的action
const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    }
  },
  actions: {
    increment (context) {
      context.commit('increment')
    }
  }
})

Action 函數(shù)接受一個與store 實例具有相同方法和屬性的context對象,因此你可以調(diào)用context.commit提交一個mutation 或者通過context.state和context.getters來獲取state和getters 實踐中我們經(jīng)常用到參數(shù)結(jié)構(gòu)來簡化代碼

actions: {
  increment ({ commit }) {
    commit('increment')
  }
}

分發(fā)Action

Action通過 store.dispatch 方法觸發(fā):

store.dispatch('increment')

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

// 以載荷形式分發(fā)
store.dispatch('incrementAsync', {
  amount: 10
})

// 以對象形式分發(fā)
store.dispatch({
  type: 'incrementAsync',
  amount: 10
})

在組件中分發(fā) Action

在組件中使用this.$store.dispatch('xxx')分發(fā)action

Module

由于使用單一狀態(tài)樹圾浅,應(yīng)用的所有狀態(tài)會集中到一個比較大的對象掠手,當(dāng)應(yīng)用變得非常復(fù)雜時,store對象就有可能變得臃腫
為了解決以上問題狸捕,Vuex允許我們將store分割成模塊喷鸽,每個模塊擁有自己的state、mutation灸拍、action做祝、getter 甚至是嵌套子模塊

const moduleA = {
  state: { ... },
  mutations: { ... },
  actions: { ... },
  getters: { ... }
}

const moduleB = {
  state: { ... },
  mutations: { ... },
  actions: { ... }
}

const store = new Vuex.Store({
  modules: {
    a: moduleA,
    b: moduleB
  }
})

store.state.a // -> moduleA 的狀態(tài)
store.state.b // -> moduleB 的狀態(tài)

參考資料:
Vuex

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鸡岗,隨后出現(xiàn)的幾起案子混槐,更是在濱河造成了極大的恐慌,老刑警劉巖纤房,帶你破解...
    沈念sama閱讀 222,378評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纵隔,死亡現(xiàn)場離奇詭異,居然都是意外死亡炮姨,警方通過查閱死者的電腦和手機捌刮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,970評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來舒岸,“玉大人绅作,你說我怎么就攤上這事《昱桑” “怎么了俄认?”我有些...
    開封第一講書人閱讀 168,983評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長洪乍。 經(jīng)常有香客問我眯杏,道長,這世上最難降的妖魔是什么壳澳? 我笑而不...
    開封第一講書人閱讀 59,938評論 1 299
  • 正文 為了忘掉前任岂贩,我火速辦了婚禮,結(jié)果婚禮上巷波,老公的妹妹穿的比我還像新娘萎津。我一直安慰自己,他們只是感情好抹镊,可當(dāng)我...
    茶點故事閱讀 68,955評論 6 398
  • 文/花漫 我一把揭開白布锉屈。 她就那樣靜靜地躺著,像睡著了一般垮耳。 火紅的嫁衣襯著肌膚如雪颈渊。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,549評論 1 312
  • 那天,我揣著相機與錄音儡炼,去河邊找鬼妓湘。 笑死,一個胖子當(dāng)著我的面吹牛乌询,可吹牛的內(nèi)容都是我干的榜贴。 我是一名探鬼主播,決...
    沈念sama閱讀 41,063評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼妹田,長吁一口氣:“原來是場噩夢啊……” “哼唬党!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鬼佣,我...
    開封第一講書人閱讀 39,991評論 0 277
  • 序言:老撾萬榮一對情侶失蹤驶拱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后晶衷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蓝纲,經(jīng)...
    沈念sama閱讀 46,522評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,604評論 3 342
  • 正文 我和宋清朗相戀三年晌纫,在試婚紗的時候發(fā)現(xiàn)自己被綠了税迷。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,742評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡锹漱,死狀恐怖箭养,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情哥牍,我是刑警寧澤毕泌,帶...
    沈念sama閱讀 36,413評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站嗅辣,受9級特大地震影響撼泛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜澡谭,卻給世界環(huán)境...
    茶點故事閱讀 42,094評論 3 335
  • 文/蒙蒙 一坎弯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧译暂,春花似錦、人聲如沸撩炊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,572評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拧咳。三九已至伯顶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背祭衩。 一陣腳步聲響...
    開封第一講書人閱讀 33,671評論 1 274
  • 我被黑心中介騙來泰國打工灶体, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人掐暮。 一個月前我還...
    沈念sama閱讀 49,159評論 3 378
  • 正文 我出身青樓蝎抽,卻偏偏與公主長得像,于是被迫代替她去往敵國和親路克。 傳聞我的和親對象是個殘疾皇子樟结,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,747評論 2 361

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

  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統(tǒng)中,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,945評論 0 7
  • Vuex 是一個專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式精算。它采用集中式存儲管理應(yīng)用的所有組件的狀態(tài)瓢宦,并以相應(yīng)...
    白水螺絲閱讀 4,670評論 7 61
  • Vuex是什么? Vuex 是一個專為 Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式灰羽。它采用集中式存儲管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,124評論 0 6
  • vuex是一個狀態(tài)管理模式驮履,通過用戶的actions觸發(fā)事件,然后通過mutations去更改數(shù)據(jù)(你也可以說狀態(tài)...
    Ming_Hu閱讀 2,026評論 3 3
  • ? Allow Compaction(允許壓縮):使用此設(shè)置后廉嚼,如有必要玫镐,AIDAPro將在辨識時壓縮FIR系數(shù)。...
    橡果閱讀 332評論 0 0