vue.js 之 vuex(狀態(tài)管理)

1. 狀態(tài)管理(vuex)簡(jiǎn)介

  • vuex是專(zhuān)為vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化。vuex也集成vue的官方調(diào)試工具devtools extension,提供了諸如零配件的time-travel調(diào)試、狀態(tài)快照導(dǎo)入導(dǎo)出等高級(jí)調(diào)試功能。

vuex配置

  • npm
npm install vuex --save
  • 在一個(gè)模塊化的打包系統(tǒng)中,您必須顯式地通過(guò) Vue.use() 來(lái)安裝 Vuex
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

2. 狀態(tài)管理核心

狀態(tài)管理有5個(gè)核心,分別是state、getter、mutation、action以及module。分別簡(jiǎn)單的介紹一下它們:

  1. state
    state為單一狀態(tài)樹(shù),在state中需要定義我們所需要管理的數(shù)組、對(duì)象、字符串等等,只有在這里定義了,在vue.js的組件中才能獲取你定義的這個(gè)對(duì)象的狀態(tài)。
  2. getter
    getter有點(diǎn)類(lèi)似vue.js的計(jì)算屬性,當(dāng)我們需要從store的state中派生出一些狀態(tài),那么我們就需要使用getter,getter會(huì)接收state作為第一個(gè)參數(shù),而且getter的返回值會(huì)根據(jù)它的依賴(lài)被緩存起來(lái),只有g(shù)etter中的依賴(lài)值(state中的某個(gè)需要派生狀態(tài)的值)發(fā)生改變的時(shí)候才會(huì)被重新計(jì)算。
  3. mutation
    更改store中state狀態(tài)的唯一方法就是提交mutation,就是類(lèi)似事件。每個(gè)mutation都有一個(gè)字符串類(lèi)型的事件類(lèi)型和一個(gè)回調(diào)函數(shù),我們需要改變state的值就要在回調(diào)函數(shù)中改變。我們要執(zhí)行這個(gè)回調(diào)函數(shù),那么我們需要執(zhí)行一個(gè)相應(yīng)的回調(diào)方法:staore.commit。
  4. avtion
    action可以提交mutation,在action中可以執(zhí)行store.commit,而且action中可以有任何的異步操作。在頁(yè)面中如果我們要調(diào)用這個(gè)action,則需要執(zhí)行store.dispatch。
  5. module
    module其實(shí)只是解決了當(dāng)state中佷復(fù)雜臃腫的時(shí)候,module可以將store分割成模塊,每個(gè)模塊中擁有自己的state、mutation、action和getter。

以上就是vuex的組成介紹,之后會(huì)將vuex中的五個(gè)核心單獨(dú)講解如何使用。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • vuex是一個(gè)狀態(tài)管理工具,類(lèi)似于redux. 安裝vuex Vuex 的狀態(tài)管理存儲(chǔ)是響應(yīng)式的:就是當(dāng)你的組件使...
    壹點(diǎn)微塵閱讀 345評(píng)論 0 1
  • Vuex是什么? Vuex 是一個(gè)專(zhuān)為 Vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,231評(píng)論 0 6
  • Vuex 是什么? Vuex 是一個(gè)專(zhuān)為 Vue.js 應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有...
    skycolor閱讀 927評(píng)論 0 1
  • 前言 之前幾篇解析 Vue 源碼的文章都是完整的分析整個(gè)源碼的執(zhí)行過(guò)程,這篇文章我會(huì)將重點(diǎn)放在核心原理的解析,不會(huì)...
    心_c2a2閱讀 1,554評(píng)論 1 8
  • 隨筆 香飄千里路花落手中樽
    _翀閱讀 235評(píng)論 0 1

友情鏈接更多精彩內(nèi)容