Vuex的安裝、搭建及案例詳解
前言
本文講訴了Vuex的安裝、搭建。以及Actions、Mutations、State、Getters的使用,為什么使用mapState、mapGetters以及一些細(xì)節(jié)的解釋
Vuex原理講解
Actions:詞義是 動作行為
Mutations:詞義是加工、維護
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-08vue項目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼
這篇文章主要介紹了vue項目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12vscode中的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-09vue視頻播放插件vue-video-player的具體使用方法
這篇文章主要介紹了vue視頻播放插件vue-video-player的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11