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

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

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

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

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

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的架子就搭好了,實戰(zhàn)演練一下,并借此機會深入的介紹一下Vuex里面的屬性。
求和案例
流程講解:點擊button按鈕,觸發(fā)點擊事件,派發(fā)消息去Actions里面找addSum,并且攜帶參數(shù)1。在Actions里面,接受參數(shù),向Mutation提交,攜帶參數(shù)1。Mutation里改變state里的sum的值,vue檢測到sum改變,重新渲染整個頁面。
效果圖:

Coute.vue
<template>
<div>
<h1>當(dāng)前的值是:{{sum}}</h1>
<button @click="addSum">點我加1</button>
<button>點我減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è)置四個參數(shù),并打印一下。


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

Mutations


同樣Mutations里面也是只有兩個參數(shù),其中第一個是state(看到了sum),第二個就是攜帶的、值。Mutations最大的作用就是可以改變state的值。
疑問:為什么需要一個Actions,求和案例之中,我把參數(shù)傳給Actions,Actions原封不動的又傳給了Mutations,為什么我不直接傳給Mutations呢?
答:確實是這樣子。如果參數(shù)確定的話,可以跳過Actions,直接commit到Mutations里面。但是如果參數(shù)不確定的話,比如我需要向服務(wù)器要數(shù)據(jù),這時候就必須用到Actions發(fā)送Ajax。
getters的使用:
如果多個組件都用到一個對state里數(shù)據(jù)處理過的值,比如求和案例中sum的20倍。通過getters僅處理一次,就可以讓多個組件同時使用。
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)在我們有多個數(shù)據(jù),怎么樣在任意組件里面訪問的到呢?為了表現(xiàn)出組件之間的通信。新建一個組件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 的引入

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

為什么要用...mapState。 原因:mapState報錯

為什么報錯呢?
輸出一下mapState()來看看。

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

效果都是可以的

mapGetters同理,就不贅述了
【錯誤示范--使用Vuex時】
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)報了一個這樣的錯誤(Vue.use(Vuex)應(yīng)該在創(chuàng)建store之前執(zhí)行),然后仔細(xì)檢查了一遍,確認(rèn)Vue.use(Vuex)寫在了引入store之前。為什么還報錯呢?這里我想說的就是Vue在解析代碼的時候,會按順序首先執(zhí)行所有的import的語句,所以Vue.use(Vuex)只能寫在store里面
【報錯】

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

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

