Vuex的安裝、搭建及案例詳解
前言
本文講訴了Vuex的安裝、搭建。以及Actions、Mutations、State、Getters的使用,為什么使用mapState、mapGetters以及一些細(xì)節(jié)的解釋
Vuex原理講解

Actions:詞義是 動(dòng)作行為
Mutations:詞義是加工、維護(hù)
State:詞義是 狀態(tài)和數(shù)據(jù)
Dispatch:詞義是派遣、發(fā)出
Commit:提交
Render: 渲染
Mutate:轉(zhuǎn)變
從這些單詞中,大體上可以概括整個(gè)圖的流程。
VC派發(fā)(Dispatch)消息到Actions,Actions提交(Commit)到Mutation,Mutation轉(zhuǎn)變(Mutate)state,然后重新渲染整個(gè)頁面。
1、安裝vuex組件
注意:vue3只能用vuex4版本,vue2只能用vuex3版本。2022年2月7日之后,vue3成了默認(rèn)版本,vuex4相應(yīng)的也成了默認(rèn)版本。所以對(duì)于vue2,要注明vuex的版本 @3

在package.json里看到vuex就說明安裝成功了

2、使用Vuex
首先需要?jiǎng)?chuàng)建一個(gè)Store。
在Src中,創(chuàng)建一個(gè)名為store的文件夾,里面包含一個(gè)index.js的文件

由上面那個(gè)原理圖可以看出來,store里面至少包含Actions,Mutations,State。
如下圖
(創(chuàng)建Store實(shí)例,需要用到Vuex.Store所以需要引用Vuex)
Vue.use(Vuex)的作用就是讓vue承認(rèn)store這個(gè)屬性,否則初始化Vc的時(shí)候,vue不會(huì)解析store這個(gè)屬性

main.js配置如下
其中store相當(dāng)于store:store。根據(jù)ES6語法規(guī)則,如果key和value一樣,可以簡寫成key的形式
import Vue from 'vue'
import App from './App.vue'
Vue.config.productionTip = false
import store from './store'
new Vue({
render: h => h(App),
store
}).$mount('#app')這樣Vuex的架子就搭好了,實(shí)戰(zhàn)演練一下,并借此機(jī)會(huì)深入的介紹一下Vuex里面的屬性。
求和案例
流程講解:點(diǎn)擊button按鈕,觸發(fā)點(diǎn)擊事件,派發(fā)消息去Actions里面找addSum,并且攜帶參數(shù)1。在Actions里面,接受參數(shù),向Mutation提交,攜帶參數(shù)1。Mutation里改變state里的sum的值,vue檢測到sum改變,重新渲染整個(gè)頁面。
效果圖:

Coute.vue
<template>
<div>
<h1>當(dāng)前的值是:{{sum}}</h1>
<button @click="addSum">點(diǎn)我加1</button>
<button>點(diǎn)我減1</button>
</div>
</template>
<script>
export default {
name:"Coute",
methods:{
addSum()
{
this.$store.dispatch('addSum',1);
}
},
computed:{
sum()
{
return this.$store.state.sum;
}
}
}
</script>
<style>
button{
margin-right: 2px;
}
</style>store.js
import Vuex from 'vuex'
import Vue from 'vue'
Vue.use(Vuex)
const state = {
sum:1
};
const mutations={
ADDSUM(state,value)
{
state.sum+=value;
}
};
const actions={
addSum(context,value)
{
context.commit('ADDSUM',value);
}
};
export default new Vuex.Store({
state,
mutations,
actions
})詳細(xì)看一下Action和Mutations里面的可以攜帶參數(shù)
Actions
設(shè)置四個(gè)參數(shù),并打印一下。


結(jié)果只輸出了兩個(gè)參數(shù),第一個(gè)參數(shù)是一個(gè)對(duì)象,里面包含了commit,dispatch等屬性,第二個(gè)參數(shù)就是要攜帶的值;
其中第二個(gè)參數(shù)叫做value,第一個(gè)參數(shù)通常叫做Context,里面最常用的是Commit。如果只想獲得Commit也可以寫成這種形式

Mutations


同樣Mutations里面也是只有兩個(gè)參數(shù),其中第一個(gè)是state(看到了sum),第二個(gè)就是攜帶的、值。Mutations最大的作用就是可以改變state的值。
疑問:為什么需要一個(gè)Actions,求和案例之中,我把參數(shù)傳給Actions,Actions原封不動(dòng)的又傳給了Mutations,為什么我不直接傳給Mutations呢?
答:確實(shí)是這樣子。如果參數(shù)確定的話,可以跳過Actions,直接commit到Mutations里面。但是如果參數(shù)不確定的話,比如我需要向服務(wù)器要數(shù)據(jù),這時(shí)候就必須用到Actions發(fā)送Ajax。
getters的使用:
如果多個(gè)組件都用到一個(gè)對(duì)state里數(shù)據(jù)處理過的值,比如求和案例中sum的20倍。通過getters僅處理一次,就可以讓多個(gè)組件同時(shí)使用。
store
import Vuex from 'vuex'
import Vue from 'vue'
Vue.use(Vuex)
const state = {
sum:1
};
const mutations={
ADDSUM(state,value)
{
state.sum+=value
}
};
const actions={
addSum({commit},value)
{
commit('ADDSUM',value)
}
};
const getters = {
bigSum(state)
{
return state.sum*20
}
}
export default new Vuex.Store({
state,
mutations,
actions,
getters
})
Store倉庫數(shù)據(jù)的使用:

現(xiàn)在我們有多個(gè)數(shù)據(jù),怎么樣在任意組件里面訪問的到呢?為了表現(xiàn)出組件之間的通信。新建一個(gè)組件Information
答案就是在Computed里面獲得
<template>
<div>
<h1>姓名:{{name}}</h1>
<h1>學(xué)校:{{school}}</h1>
<h1>爵位:{{Marquis}}</h1>
</div>
</template>
<script>
export default {
name:'Information',
computed:{
school()
{
return this.$store.state.school;
},
sum()
{
return this.$store.state.sum;
},
name()
{
return this.$store.state.name;
},
Marquis()
{
return this.$store.state.Marquis;
}
}
}
</script>
<style>
</style>效果圖

GetState 的引入

由上圖所示,這樣一個(gè)一個(gè)的寫,雖然可以寫出來,但是實(shí)在是太麻煩了。干的都是一樣的工作。所以Vue給我們提供了一個(gè)方法。mapState和mapGetters。這兩個(gè)一個(gè)是簡化State里的屬性,一個(gè)是簡化getters里面的屬性。
第一種方法可以簡寫成下面這種形式。(對(duì)象寫法。函數(shù)的名字可以隨意)

為什么要用...mapState。 原因:mapState報(bào)錯(cuò)

為什么報(bào)錯(cuò)呢?
輸出一下mapState()來看看。

mapState里面是一個(gè)對(duì)象。computed本身也是一個(gè)對(duì)象。{}里面再加一個(gè){},是肯定會(huì)報(bào)錯(cuò)的。 那為什么用...呢,ES6用法中,一個(gè)對(duì)象t1,一個(gè)對(duì)象t2,t1{...t2}就相當(dāng)于,把t2中的屬性全拿出來一個(gè)個(gè)放到t1里面。
第二種方法:數(shù)組方法(state里面的屬性是什么就必須寫什么)

效果都是可以的

mapGetters同理,就不贅述了
【錯(cuò)誤示范--使用Vuex時(shí)】
Vue.use(Vuex)在main.js里面使用
main.js
import Vue from 'vue'
import App from './App.vue'
import Vuex from 'vuex'
Vue.use(Vuex)
Vue.config.productionTip = false
import store from './store'
new Vue({
render: h => h(App),
store
}).$mount('#app')import Vuex from 'vuex'
const state = {
};
const mutations={
};
const actions={
};
const getters = {
}
export default new Vuex.Store({
state,
mutations,
actions,
getters
})
你發(fā)現(xiàn)報(bào)了一個(gè)這樣的錯(cuò)誤(Vue.use(Vuex)應(yīng)該在創(chuàng)建store之前執(zhí)行),然后仔細(xì)檢查了一遍,確認(rèn)Vue.use(Vuex)寫在了引入store之前。為什么還報(bào)錯(cuò)呢?這里我想說的就是Vue在解析代碼的時(shí)候,會(huì)按順序首先執(zhí)行所有的import的語句,所以Vue.use(Vuex)只能寫在store里面
【報(bào)錯(cuò)】

語法校驗(yàn)不過關(guān),在vue.config.js加上這句lintOnSave:false(關(guān)閉語法校驗(yàn))

總結(jié)
到此這篇關(guān)于Vuex安裝搭建及案例詳解的文章就介紹到這了,更多相關(guān)Vuex詳解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue實(shí)現(xiàn)點(diǎn)擊當(dāng)前元素以外的地方隱藏當(dāng)前元素(實(shí)現(xiàn)思路)
這篇文章主要介紹了Vue實(shí)現(xiàn)點(diǎn)擊當(dāng)前元素以外的地方隱藏當(dāng)前元素,文中給大家擴(kuò)展了vue實(shí)現(xiàn)點(diǎn)擊其他地方隱藏div的三種方法,需要的朋友可以參考下2019-12-12
對(duì)Vue2 自定義全局指令Vue.directive和指令的生命周期介紹
今天小編就為大家分享一篇對(duì)Vue2 自定義全局指令Vue.directive和指令的生命周期介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
vue項(xiàng)目中axios請(qǐng)求網(wǎng)絡(luò)接口封裝的示例代碼
這篇文章主要介紹了vue項(xiàng)目中axios請(qǐng)求網(wǎng)絡(luò)接口封裝的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12
Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫進(jìn)度功能
這篇文章主要介紹了Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫進(jìn)度功能,此功能可以幫助用戶了解表單填寫的進(jìn)度和當(dāng)前狀態(tài),提高用戶體驗(yàn),通常實(shí)現(xiàn)的方式是在表單中添加進(jìn)度條,根據(jù)用戶填寫狀態(tài)動(dòng)態(tài)更新進(jìn)度條,感興趣的同學(xué)可以參考下文2023-05-05
vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘Combin
這篇文章主要介紹了vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
vue視頻播放插件vue-video-player的具體使用方法
這篇文章主要介紹了vue視頻播放插件vue-video-player的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
VSCode創(chuàng)建Vue項(xiàng)目的完整步驟教程
Vue是一個(gè)輕量級(jí)、漸進(jìn)式的Javascript框架,如果想要要開發(fā)全新的Vue項(xiàng)目,建議項(xiàng)目構(gòu)建工具vue-cli,下面這篇文章主要給大家介紹了關(guān)于VSCode創(chuàng)建Vue項(xiàng)目的完整步驟,需要的朋友可以參考下2022-06-06

