vuex學習筆記

VUEX

是一個狀態管理模式,可以集中式存儲和管理組件的狀態。

組件使用store里面的state作數據展示,通過dispatch action來處理異步業務邏輯,然后commit mutations處理同步業務邏輯并且更新state

Store

const store = {
  state,
  mutaions,
  getters,
  actions,
  modules
}

State

通過在跟組件中注冊store,即new Vue({store}),該store實例會注入到根組件下的所有子組件中,子組件通過this.$store.state去訪問屬性。

// 可以通過mapState來幫我們生成計算屬性
import { mapState } from 'vuex'
export default {
  computed:{
    aaa,
    // 自己本來有computed的屬性
    ...mapState({
      count:state => state.count,
      // 也可以傳 'count' 等同于 'state => state.count'
      'count'
    }),
    ...mapState([
      'xxx',
      'yyy'
    ])
  }
}

Getters

當多個組件需要一種清洗和過濾后的數據的時候,可以編寫getters,即處理數據格式的一種方法。

// 定義一個getters,里面有個sum
const getters = {
  // 也可以接收一個getters作為參數
  sum:( state,getters ) => {
    return state.a + state.b;
  }
}
// 使用getters
computed:{
  // 同樣使用拓展運算符將 getters 混入 computed 對象中
  xxx,
  ...mapGetters([
    'aaa',
    'bbb'
  ])  
}

Mutations

更改Vuex中的state狀態的唯一方法是commit mutation,然后在mutation中操縱state改變狀態。

// 定義
const mutations = {
  // 可以傳入額外的參數n
  [ADD](state,obj){
    state.count += obj.n;
  }
}

// 一般使用常量替代 mutation 事件類型
const ADD = 'ADD'

//調用,type對應方法名, 或者commit('add',10)
store.commit({
  type:'add',
  n:10
}) 

mutation必須是同步函數,也就是說所有異步請求應該都放在action

// 使用
export default {
  methods:{
    ...mapMutations([
      // 映射 this.aaa() 為 this.$store.commit('aaa')
      'aaa'
    ])
  }
}

Action

action類似mutation,但是actioncommit mutation,而不是直接改變狀態,并且action可以進行異步操作。

const actions = {
  //這里需要注意,入參的context是一個modules,不是Store,有store實例的相同方法和屬性
  aaa(context,n){
    // 在action中提交一個type為aaa的mutation
    context.commit({type:'mutation',n:n})
  }
}

// 調用
store.dispatch({type:'aaa',n:10}); //dispatch('aaa',n)
// 使用
export default {
  methods:{
    ...mapActions([
      // 映射 this.aaa() 為 this.$store.dispatch('aaa')
      'aaa'
    ])
  }
}

Modules

一個很大的單頁項目,如果所有狀態都集中在一個Store上,那么這個Store就會很大,所以將store分割模塊,每個模塊擁有自己的state,mutation,action,getters.

const moduleA = {
  state,
  actions,
  mutations
}
const moduleB = {
  state,
  actions,
  mutations
}

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

Store.state.moduleA // -> moduleA 的狀態

規則

  • 應用層級的狀態應該集中到單個 Store 對象
  • 提交 mutation 是更改狀態的唯一方法,并且這個過程是同步的
  • 異步邏輯都應該封裝到 action 里面
  • 對大型項目,需要把 Vuex 相關代碼分割到模塊中
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,362評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,013評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,346評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,421評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,146評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,534評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,585評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,767評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,318評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,074評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,258評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,828評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,486評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,916評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,156評論 1 290
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,993評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,234評論 2 375

推薦閱讀更多精彩內容

  • Vuex 是什么? ** 官方解釋:Vuex 是一個專為 Vue.js 應用程序開發的狀態管理模式**。它采用集中...
    Rz______閱讀 2,315評論 1 10
  • vuex 狀態管理器 作為應用中所有組件的中央儲存 只能以預定的方式去操作狀態 把所有組件共享的狀態抽取出來作為全...
    一只大椰子閱讀 798評論 0 1
  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統中,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,960評論 0 7
  • Vuex是什么? Vuex 是一個專為 Vue.js應用程序開發的狀態管理模式。它采用集中式存儲管理應用的所有組件...
    蕭玄辭閱讀 3,131評論 0 6
  • vuex 場景重現:一個用戶在注冊頁面注冊了手機號碼,跳轉到登錄頁面也想拿到這個手機號碼,你可以通過vue的組件化...
    sunny519111閱讀 8,032評論 4 111