VUEX全局狀態(tài)管理

Vuex

Vuex是類似Flux的狀態(tài)管理庫碍脏,專門用于Vue的狀態(tài)管理帅霜。

對于那些不熟悉的人來說奸攻,Flux是Facebook創(chuàng)造的一種設(shè)計(jì)模式蒜危。Flux模式由四個(gè)部分組成,組成單向數(shù)據(jù)管道:

image

Vuex的靈感主要來自Flux和Elm Architecture睹耐。Vuex集成的核心是Vuex存儲辐赞。

// store.js
const store = new Vuex.Store({
    state,
    mutations,
    actions,
    getters
})

Vuex存儲(Vuex Store)包含四個(gè)對象:statemutations硝训、actionsgetters响委。

state 只是一個(gè)包含需要在應(yīng)用程序中共享的屬性的對象。

// store.js
const state = {
    numbers: [1, 2, 3]
}

這個(gè)state對象只包含了一個(gè)numbers數(shù)組捎迫。

mutations是負(fù)責(zé)直接改變存儲狀態(tài)的函數(shù)晃酒。在Vuex中,mutations總是以state作為第一個(gè)參數(shù)窄绒。此外贝次,actions也可以不作為第二個(gè)參數(shù)傳遞有效負(fù)載:

// store.js
const mutations = {
    ADD_NUMBER(state, payload) {
        state.numbers.push(payload)
    }
}

在Flux架構(gòu)中,mutations中的函數(shù)通常用大寫字母表示彰导,以區(qū)別于其他函數(shù)蛔翅,并用于工具和lint目的敲茄。在上面的示例中,創(chuàng)建了一個(gè)ADD_NUMBER()mutations山析,它需要一個(gè)有效的payload并將該有效的payload推送到state.numbers數(shù)組中堰燎。

actions可以調(diào)用mutations。在提交mutations之前笋轨,actions還負(fù)責(zé)所有異步調(diào)用秆剪。actions可以訪問context對象,該對象提供對state(使用context.state)爵政、getter(使用context.getters)和commit函數(shù)(context.commit)的訪問仅讽。

下面是一個(gè)簡單的actions的示例,它只是傳遞預(yù)期的有效負(fù)載時(shí)直接提交mutations

// store.js
const actions = {
    addNumber(context, number) {
        context.commit('ADD_NUMBER', number)
    }
}

Vuex存儲中的getters就像組件中的計(jì)算屬性一樣钾挟。getters主要用于執(zhí)行一些計(jì)算和操作洁灵,以便在組件訪問這些信息之前存儲狀態(tài)。

mutations一樣掺出,getters可以訪問state作為第一個(gè)參數(shù)徽千。這里有一個(gè)叫getNumbersgetter,它只返回state.numbers數(shù)組:

// store.js
const getters = {
    getNumbers(state) {
        return state.numbers
    }
}

最后store.js的代碼如下所示:

import Vue from "vue";
import Vuex from "vuex";

Vue.use(Vuex);

const state = {
    numbers: [1, 2, 3]
};

const mutations = {
    ADD_NUMBER(state, payload) {
        state.numbers.push(payload);
    }
};

const actions = {
    addNumber(context, number) {
        context.commit("ADD_NUMBER", number);
    }
};

const getters = {
    getNumbers(state) {
        return state.numbers;
    }
};

export default new Vuex.Store({
    state,
    mutations,
    actions,
    getters
});

對于這樣簡單的一個(gè)示例汤锨,可能不一定需要Vuex存儲双抽。上面的示例只是用來向大家展示如何使用Vuex和簡單的全局存儲在實(shí)現(xiàn)上的直接區(qū)別。

當(dāng)Vuex存儲準(zhǔn)備好之后泥畅,Vue應(yīng)用程序可以在Vue實(shí)例中聲明store對象荠诬,可以提供給Vue應(yīng)用程序使用。

// main.js
import Vue from "vue";
import App from "./App";
import store from "./store";

new Vue({
    el: '#app',
    store,
    components: {
        App
    },
    template: '<App />'
})

有了Vuex存儲之后位仁,組件通掣陶辏可以執(zhí)行以下兩種操作之一。他們要么:獲饶羟馈(GET)狀態(tài)信息(通過訪問storestategetters)或者 調(diào)用(DISPATCHactions钧嘶。

下面創(chuàng)建的NumberDisplay組件,它通過將getNumbers存儲getter映射到組件getNumbers計(jì)算屬性來直接顯示state.numbers數(shù)組琳疏。

<!-- NumberDisplay.vue -->
<template>
    <div>
        <h2>{{ getNumbers }}</h2>
    </div>
</template>

<script>
    export default {
        name: 'NumberDisplay',
        computed: {
            getNumbers() {
                return this.$store.getters.getNumbers
            }
        }
    }
</script>

接著再創(chuàng)建一個(gè)NumberSubmit組件有决,允許用戶通過addNumber方法映射到同名的actions,然后將新輸入的數(shù)字添加到state.numbers

<!-- NumberSubmit.vue -->
<template>
    <div class="form">
        <input v-model="numberInput" type="number" />
        <button @click="addNumber(numberInput)">Add new number</button>
    </div>
</template>

<script>
    export default {
        name: 'NumberSubmit',
        data: () => ({
            numberInput: 0
        }),
        methods: {
            addNumber(numberInput) {
                this.$store.dispatch('addNumber', Number(numberInput))
            }
        }
    }
</script>

最后在App.vue中引入前面創(chuàng)建的組件:

<!-- App.vue -->
<template>
    <div id="app">
        <NumberDisplay/>
        <NumberSubmit/>
    </div>
</template>

<script>
    import NumberDisplay from "./components/NumberDisplay";
    import NumberSubmit from "./components/NumberSubmit";

    export default {
        name: "App",
        components: {
            NumberDisplay,
            NumberSubmit
        }
    };
</script>

我們可以看到空盼,Vuex通過引入顯式定義的actions书幕、mutationsgetters 擴(kuò)展了簡單的存儲方法。這就是使用Vuex的最初標(biāo)準(zhǔn)和主要優(yōu)勢所在揽趾。此外台汇,Vuex和vue-devtools集成在一起,提供了更易的調(diào)試功能。

下圖就是一個(gè)關(guān)于vue-devtools如何幫助我們在發(fā)生突變時(shí)觀察存儲信息:

image

Vuex不是唯一個(gè)用來管理Vue狀態(tài)的庫苟呐,類似于Flux的庫在社區(qū)中還有很多種痒芝,比如redux-vuevuejs-redux,用于擴(kuò)展Redux牵素。然而严衬,由于Vuex是專門為Vue應(yīng)用程序而定制的,因此它無疑是最容易與Vue應(yīng)用程序集成在一起笆呆。

Vuex擴(kuò)展了簡單的存儲方法请琳,使我們的應(yīng)用程序的狀態(tài)管理變得更簡單。
原文: https://www.w3cplus.com/vue/managing-state-in-vue-js.html?utm_source=tuicool&utm_medium=referral ? w3cplus.com

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末腰奋,一起剝皮案震驚了整個(gè)濱河市单起,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌劣坊,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屈留,死亡現(xiàn)場離奇詭異局冰,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)灌危,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門康二,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人勇蝙,你說我怎么就攤上這事沫勿。” “怎么了味混?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵产雹,是天一觀的道長。 經(jīng)常有香客問我翁锡,道長蔓挖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任馆衔,我火速辦了婚禮瘟判,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘角溃。我一直安慰自己拷获,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布减细。 她就那樣靜靜地躺著匆瓜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上陕壹,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天质欲,我揣著相機(jī)與錄音,去河邊找鬼糠馆。 笑死嘶伟,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的又碌。 我是一名探鬼主播九昧,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼毕匀!你這毒婦竟也來了铸鹰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤皂岔,失蹤者是張志新(化名)和其女友劉穎蹋笼,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體躁垛,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡剖毯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了教馆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片逊谋。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖土铺,靈堂內(nèi)的尸體忽然破棺而出胶滋,到底是詐尸還是另有隱情,我是刑警寧澤悲敷,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布究恤,位于F島的核電站,受9級特大地震影響镀迂,放射性物質(zhì)發(fā)生泄漏丁溅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一探遵、第九天 我趴在偏房一處隱蔽的房頂上張望窟赏。 院中可真熱鬧,春花似錦箱季、人聲如沸涯穷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拷况。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間赚瘦,已是汗流浹背粟誓。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留起意,地道東北人鹰服。 一個(gè)月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像揽咕,于是被迫代替她去往敵國和親悲酷。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344