摘要:使用,引入之后用進(jìn)行引用。在模板中引入們剛建的文件,并在模板中用輸出的值。在文件中加入兩個(gè)改變的方法。和單純的全局對(duì)象有以下兩點(diǎn)不同的狀態(tài)存儲(chǔ)是響應(yīng)式的。改變中的狀態(tài)的唯一途徑就是顯式地提交。
vuex 是什么?
Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式。
通俗的解釋就是,Vuex 就是為 vue 組件之間進(jìn)行數(shù)據(jù)共享而開發(fā)的插件。
對(duì)于父子組件,可以通過 props 實(shí)現(xiàn)數(shù)據(jù)通信;
不同非父子組件可以引入 vue 對(duì)象通過 $emit/$on 實(shí)現(xiàn);
也可以通過不大優(yōu)雅的 localStorage 存儲(chǔ);
vuex 是另一種解決方案,如果不同組件有大量數(shù)據(jù)需要共享通信,vuex 會(huì)更適合。
開始首先搭建一個(gè) vue 項(xiàng)目,安裝 vuex。
NPMnpm n install vuex --save
需要注意的是這里一定要加上 –save,因?yàn)槟氵@個(gè)包我們?cè)谏a(chǎn)環(huán)境中是要使用的。
Yarnyarn add vuex直接下載 / CDN 引用
https://unpkg.com/vuex
下載到本地,引入
并不推薦用 script 方式引入
在項(xiàng)目中新建一個(gè) vuex 文件夾,并在文件夾下新建 store.js 文件,文件中我們的 vue 和vuex。
import Vue from "vue"; import Vuex from "vuex";
使用 vuex,引入之后用 Vue.use 進(jìn)行引用。
Vue.use(Vuex);初嘗試 demo
1.在 store.js 文件里增加一個(gè)常量對(duì)象。
const state = { count:1 }
2.用 export default 輸出對(duì)象,讓外部可以引用。
export default new Vuex.Store({ state })
3.新建一個(gè) vue 組件,在 components 文件夾下,命名 counter.vue。 在模板中引入們剛建的 store.js 文件,并在模板中用 {{ $store.state.count }} 輸出 count 的值。
{{ msg }}
{{ $store.state.count }}
4.在 store.js 文件中加入兩個(gè)改變 state 的方法。
const mutations={ add(state){ state.count++; }, reduce(state){ state.count--; } } export default new Vuex.Store({ state, mutations })
5.在 counter.vue 模板中加入兩個(gè)按鈕,并調(diào)用 mutations 中的方法。
點(diǎn)擊按鈕可以看到count數(shù)字的變化。
訪問state數(shù)據(jù) 1.通過 computed 計(jì)算屬性獲取到 countcomputed: { count () { return this.$store.state.count } }
或者
computed: { count () { return store.state.count } }
在模板里直接訪問 {{ count }} 變能獲取到,
$store 即掛載在vue實(shí)例屬性上的 store 對(duì)象
通過 this.$store 可以訪問 store 實(shí)例后的屬性和方法
import { mapState } from "vuex" computed: mapState({ // 箭頭函數(shù)可使代碼更簡(jiǎn)練 count: state => state.count, })
我們也可以給 mapState 傳一個(gè)字符串?dāng)?shù)組。
computed: mapState([ // 映射 this.count 為 store.state.count "count" ])
mapState 可以接受函數(shù)也可以接受一個(gè)數(shù)組,最后都統(tǒng)一返回一個(gè) key value 形式的對(duì)象,使用數(shù)組意味著 key 和 value 名稱是一樣的。
當(dāng)你需要獲取多個(gè)數(shù)據(jù)時(shí),mapState 可使代碼更簡(jiǎn)練。
如果 computed 需要寫多個(gè)對(duì)象,展開運(yùn)算符會(huì)是一個(gè)很棒的選擇。
computed:{ ...mapState(["count"]), ...mapGetters(["count"]) }Mutations 修改狀態(tài)
狀態(tài)可以理解為 state 數(shù)據(jù),我們不能直接改變 this.$store.state 里的數(shù)據(jù),需要調(diào)用 vuex 本身封裝出來(lái)的方法,而這也恰好體現(xiàn)了單一數(shù)據(jù)流,
$store.commit( )Vuex 提供了 commit 方法來(lái)修改狀態(tài),我們看一下在 demo 中所寫的。
const mutations={ add(state){ state.count++; }, reduce(state){ state.count--; } }傳值(payload)
mutations的方法,第一個(gè)默認(rèn)就是 state,第二個(gè)參數(shù)才是你所傳遞的
const mutations={ add(state,n){ state.count+=n; } }
除了字符串?dāng)?shù)字類型,還可以傳遞對(duì)象裝載更多數(shù)據(jù)
mutations: { add (state, payload) { state.count += payload.amount } }
store.commit(add, { amount: 10 }) // 也可以 store.commit({ type: "add", amount: 10 })獲取 Mutations方法
import { mapState,mapMutations } from "vuex"; methods:mapMutations([ "add","reduce" ]) // 也可以 methods:mapMutations({ add: "add", reduce: "reduce" })
methods 還可以
methods: { ...mapMutations([ "add","reduce" ]), other () { } }
推薦使用數(shù)組方式,更為簡(jiǎn)單方便
getters 計(jì)算過濾在 store.js 里用 const 聲明我們的 getters 對(duì)象
const getters = { evenOrOdd: state => state.count % 2 === 0 ? "even" : "odd" }
把寫好的 getters 傳給 Vuex.Store 對(duì)象,輸出
export default new Vuex.Store({ state, mutations, getters })
在組件里應(yīng)用
import {mapState, mapMutations, mapGetters} from "vuex";
computed:{ ...mapState(["count"]), ...mapGetters(["evenOrOdd"]), },
{{ evenOrOdd }}
便能獲取到 evenOrOdd 的值
actions 異步修改狀態(tài)Action
類似于 mutation,不同點(diǎn)是,Action 提交的是 mutation,actions 是異步的改變狀態(tài),而 Mutations 是同步改變狀態(tài)。
注冊(cè)一個(gè)簡(jiǎn)單的 actions:
const actions ={ addAction(context){ context.commit("add",10) }, reduceAction({commit}){ commit("reduce") } } export default new Vuex.Store({ state, mutations, getters, actions })
context是上下文對(duì)象,也就是就是 store 對(duì)象
通過參數(shù)解構(gòu)可以直接拿到commit
和mutation類似
直接調(diào)用 mutation 方法是 commit 調(diào)用,Action方法是使用 dispatch
也可以使用輔助函數(shù)
methods:{ ...mapMutations(["add","reduce"]), ...mapActions(["addAction","reduceAction"]) },
Actions 支持同樣的載荷方式和對(duì)象方式進(jìn)行分發(fā):
// 以載荷形式分發(fā) store.dispatch("addAction", { amount: 10 }) // 以對(duì)象形式分發(fā) store.dispatch({ type: "addAction", amount: 10 })
actions 本身是用 promise 封裝實(shí)現(xiàn),dispatch 依然返回 promise
所以你可以
store.dispatch("actionA").then(() => { // ... })
也可以
actions: { actionB ({ dispatch, commit }) { return dispatch("actionA").then(() => { commit("someOtherMutation") }) } }
actions 往往用于結(jié)合 axios 實(shí)現(xiàn)異步請(qǐng)求數(shù)據(jù)
Module大型項(xiàng)目多人開發(fā)大量的數(shù)據(jù)共享時(shí),建議使用 Module
之前寫法
export default new Vuex.Store({ state, mutations, getters, actions })
Module 寫法
const moduleA = { state: { ... }, mutations: { ... }, actions: { ... }, getters: { ... } } const moduleB = { state: { ... }, mutations: { ... }, actions: { ... } } const store = new Vuex.Store({ modules: { a: moduleA, b: moduleB } })
調(diào)用從 store.state.count
應(yīng)寫成
store.state.a.count
若共享數(shù)據(jù)很多,可以給數(shù)據(jù)分組。
總結(jié)state 用于數(shù)據(jù)存儲(chǔ)
Getter 相當(dāng)于 state 的計(jì)算屬性
Mutation 是改變 state 的方法
Action 是異步改變,提交給 Mutation
分別對(duì)應(yīng)輔助函數(shù) mapState,mapGetter,mapMutation,mapAction
commit 調(diào)用 Mutation 方法
dispatch 是調(diào)用 Action 方法
最后看 vuex 流程圖,是不是大徹大悟了?
vuex 使用單一狀態(tài)樹——用一個(gè)對(duì)象就包含了全部的應(yīng)用層級(jí)狀態(tài)。這也意味著,每個(gè)應(yīng)用將僅僅包含一個(gè) store 實(shí)例。單一狀態(tài)樹能夠直接地定位任一特定的狀態(tài)片段,在調(diào)試的過程中也能輕易地取得整個(gè)當(dāng)前應(yīng)用狀態(tài)的快照。
每一個(gè) Vuex 應(yīng)用的核心就是 store(倉(cāng)庫(kù))。store 基本上就是一個(gè)容器,它包含著應(yīng)用中大部分的狀態(tài) (state)。Vuex 和單純的全局對(duì)象有以下兩點(diǎn)不同:
1、Vuex 的狀態(tài)存儲(chǔ)是響應(yīng)式的。當(dāng) Vue 組件從 store 中讀取狀態(tài)的時(shí)候,若 store 中的狀態(tài)發(fā)生變化,那么相應(yīng)的組件也會(huì)相應(yīng)地得到高效更新
2、不能直接改變 store 中的狀態(tài)。改變 store 中的狀態(tài)的唯一途徑就是顯式地提交 (commit) mutation。這樣使得可以方便地跟蹤每一個(gè)狀態(tài)的變化,從而能夠?qū)崿F(xiàn)一些工具幫助更好地了解應(yīng)用
Vuex 背后的基本思想,借鑒了 Flux、Redux 和 The Elm Architecture
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/103553.html
摘要:它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化。寫需要的組件創(chuàng)建一個(gè)組件,懟下面的內(nèi)容,你喜歡彬哥哪一點(diǎn)創(chuàng)建一個(gè)展示組件我喜歡彬哥打開,刪掉沒用的東西,直接懟下面的代碼,到這里,架子就搭好了。 通過本文你將: 1.知道什么是Vuex. 2.知道為什么要用Vuex. 3.能跑一個(gè)Vuex的例子。 4.了解相關(guān)概念,面試的時(shí)候能說出一個(gè)所以然 5...
摘要:寫在前面本文旨在通過一個(gè)簡(jiǎn)單的例子,練習(xí)的幾個(gè)常用方法,使初學(xué)者以最快的速度跑起來(lái)一個(gè)的示例。生成基于的項(xiàng)目基于腳手架生成一個(gè)項(xiàng)目常用命令項(xiàng)目名進(jìn)入項(xiàng)目目錄,使用先試著跑一下。子組件可以修改父組件和自己的數(shù)據(jù)。 寫在前面 本文旨在通過一個(gè)簡(jiǎn)單的例子,練習(xí)vuex的幾個(gè)常用方法,使初學(xué)者以最快的速度跑起來(lái)一個(gè)vue + vuex的示例。 學(xué)習(xí)vuex需要你知道vue的一些基礎(chǔ)知識(shí)和用法。...
摘要:從入門到放棄自動(dòng)導(dǎo)入模塊命名空間輔助函數(shù)什么是什么是狀態(tài)管理,驅(qū)動(dòng)應(yīng)用的數(shù)據(jù)源,以聲明方式將映射到視圖,響應(yīng)在上的用戶輸入導(dǎo)致的狀態(tài)變化。最后重點(diǎn)來(lái)了外包在職萌新求內(nèi)推位置廣州 Vuex從入門到放棄(webpack自動(dòng)導(dǎo)入模塊 命名空間 輔助函數(shù)) 1.什么是vuex 1.1 什么是狀態(tài)管理 state,驅(qū)動(dòng)應(yīng)用的數(shù)據(jù)源; view,以聲明方式將 state 映射到視圖; actio...
先說一下Vuex到底是什么? Vuex 是一個(gè)專門為 vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式 這個(gè)狀態(tài)我們可以理解為在 data 中的屬性,需要共享給其他組件使用的部分 也就是說,我們需要共享的數(shù)據(jù),可以使用 vuex 進(jìn)行統(tǒng)一集中式的管理 喜歡看代碼學(xué)習(xí)的的可直接下載下方 Demo https://gitee.com/jiangliyue/... Vuex中的五種基本對(duì)象 state...
摘要:它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化。這需要對(duì)短期和長(zhǎng)期效益進(jìn)行權(quán)衡。改變中的狀態(tài)的唯一途徑就是顯式地提交。在里使用進(jìn)行延遲執(zhí)行。上下文對(duì)象,這里你可以理解稱本身。 這篇文章主要介紹了Vuex入門到上手教程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧 一、前言 當(dāng)我們的應(yīng)用遇到多個(gè)組件共享狀態(tài)時(shí),會(huì)需...
閱讀 3114·2023-04-26 01:58
閱讀 958·2021-11-24 09:38
閱讀 3291·2021-09-03 10:29
閱讀 721·2021-08-21 14:10
閱讀 1494·2019-08-30 15:44
閱讀 3094·2019-08-30 14:10
閱讀 3218·2019-08-29 16:32
閱讀 1484·2019-08-29 12:48