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)版本。所以對于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è)對象,里面包含了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è)對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里面的屬性。
第一種方法可以簡寫成下面這種形式。(對象寫法。函數(shù)的名字可以隨意)
為什么要用...mapState。 原因:mapState報(bào)錯(cuò)
為什么報(bào)錯(cuò)呢?
輸出一下mapState()來看看。
mapState里面是一個(gè)對象。computed本身也是一個(gè)對象。{}里面再加一個(gè){},是肯定會(huì)報(bào)錯(cuò)的。 那為什么用...呢,ES6用法中,一個(gè)對象t1,一個(gè)對象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)容請搜索腳本之家以前的文章或繼續(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對Vue2 自定義全局指令Vue.directive和指令的生命周期介紹
今天小編就為大家分享一篇對Vue2 自定義全局指令Vue.directive和指令的生命周期介紹,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08vue項(xiàng)目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼
這篇文章主要介紹了vue項(xiàng)目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12Vue實(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-05vscode中的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ì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09vue視頻播放插件vue-video-player的具體使用方法
這篇文章主要介紹了vue視頻播放插件vue-video-player的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11VSCode創(chuàng)建Vue項(xiàng)目的完整步驟教程
Vue是一個(gè)輕量級、漸進(jìn)式的Javascript框架,如果想要要開發(fā)全新的Vue項(xiàng)目,建議項(xiàng)目構(gòu)建工具vue-cli,下面這篇文章主要給大家介紹了關(guān)于VSCode創(chuàng)建Vue項(xiàng)目的完整步驟,需要的朋友可以參考下2022-06-06