VueX?mapGetters獲取Modules中的Getters方式
VueX mapGetters獲取Modules的Getters
注明 : permission 是你要獲取的Modules中的哪一個(gè) (permission 即是 模塊名);
? ? ? ? ...mapGetters("permission",[
? ? ? ? ? ? 'ReturnRoutes'
? ? ? ? ]),
?? ??? ?...mapGetters("模塊名",[
? ? ? ? ? ? '方法名'
? ? ? ? ]),非輔助函數(shù)映射獲取方式 :
this.$store.getters["permission/ReturnRoutes"] this.$store.getters["模塊名/方法名"]
permission 實(shí)際上傳入的是一個(gè)路徑(一般在Modules嵌套的情況下)
computed: {
? ...mapState('some/nested/module', {
? ? a: state => state.a,
? ? b: state => state.b
? })
},
methods: {
? ...mapActions('some/nested/module', [
? ? 'foo', // -> this.foo()
? ? 'bar' // -> this.bar()
? ])
};?? ??? ?createNamespacedHelpers 命名空間輔助函數(shù), 來進(jìn)行規(guī)定 輔助函數(shù)的路徑
import { createNamespacedHelpers } from 'vuex'
const { mapState, mapActions } = createNamespacedHelpers('some/nested/module')
export default {
? computed: {
? ? // 在 `some/nested/module` 中查找
? ? ...mapState({
? ? ? a: state => state.a,
? ? ? b: state => state.b
? ? })
? },
? methods: {
? ? // 在 `some/nested/module` 中查找
? ? ...mapActions([
? ? ? 'foo',
? ? ? 'bar'
? ? ])
? }
}各位碼友多讀文檔, 如果您有幸看到這篇文章, 說明您是吃了少讀文檔的虧, 和我一樣, 共勉~詳情請(qǐng)看 Vuex文檔
mapGetters的使用及簡(jiǎn)單實(shí)現(xiàn)原理
項(xiàng)目中的mapGetters
在Vue項(xiàng)目的開發(fā)過程中必然會(huì)使用到vuex,對(duì)vue項(xiàng)目公用數(shù)據(jù)進(jìn)行管理,從而解決組件之間數(shù)據(jù)相互通信的問題,如果不使用vuex,那么一些非父子組件之間的數(shù)據(jù)通信將會(huì)變得極為繁瑣。
1.這里首先說下項(xiàng)目中mapGetters的使用
先看下store部分目錄結(jié)構(gòu)

index.js文件
import Vue from 'vue'
import Vuex from 'vuex'
import book from './mudules/book'
import getters from './getters'
Vue.use(Vuex)
export default new Vuex.Store({
modules: {
book
},
getters
})
book.js文件
const book = {
state: {
number: 1
},
mutations: {
SET_NUMBER: (state, number) => {
state.number = number
}
},
actions: {
setNumber: ({commit, state}, number) => {
// console.log(state.number, number)
return commit('SET_NUMBER', number)
}
}
}
export default book
getters文件
const getters = {
number: state => state.book.number
}
export default getters
在vue組件中
import { mapGetters } from 'vuex'
export default {
computed: {
...mapGetters(['number']),
},
mounted () {
this.$store.dispatch('setNumber',10).then(() => {
console.log(this.number)
})
}
}
通過引入mapGetters 我們就可以輕松的取到vuex中存儲(chǔ)的數(shù)據(jù),從代碼中可以看出,getters就類似于vue組件中的computed(計(jì)算屬性),在組件中引入mapGetters就是將vuex中的數(shù)據(jù)映射到組件的計(jì)算屬性當(dāng)中,在組件不多,組件的數(shù)據(jù)通信不是很多的時(shí)候這樣寫看似將簡(jiǎn)單的東西復(fù)雜化了,但是在稍復(fù)雜點(diǎn)的項(xiàng)目中這樣會(huì)極大的減少工作量,及組件之間數(shù)據(jù)傳遞的復(fù)雜程度。
mapGetters簡(jiǎn)單實(shí)現(xiàn)原理
在上面的代碼中可能很多人在項(xiàng)目中用到過,但是對(duì)于其原理可能不是很理解。
可能有一部人對(duì)于在組件計(jì)算屬性中…mapGetters([‘number’]),不是很理解,下面就簡(jiǎn)單寫一個(gè)方法實(shí)現(xiàn)類似的功能。
在組件中
import { mapGetters } from 'vuex'
export default {
computed: {
...mapGetters(['number']),
//...fn(['a', 'b', 'c']) //需要實(shí)現(xiàn)這樣一個(gè)方法傳入一個(gè)數(shù)組
},
methods: {
menuClick (key) {
if (key === 0) {
this.$router.push('/ebook')
}else if (key === 1) {
this.$router.push('/datachart')
}else{
return
}
}
},
mounted () {
this.$store.dispatch('setNumber',10).then(() => {
console.log(this.number)
})
// console.log(this.a,this.b,this.c) // 在組件中可以直接通過this取到相應(yīng)的值
}
}
我們?cè)谟?jì)算屬性中添加
…fn([‘a(chǎn)', ‘b'])
要求在組件中可以直接通過
this.a 和this.b 取到相應(yīng)的值
const getters = {
a: () => 1,
b: () => 2,
c: () => 3
}
function fn (keys) {
const data = {}
keys.forEach(key => {
if (getters.hasOwnProperty(key)) {
data[key] = getters[key]
}
});
return data
}
import { mapGetters } from 'vuex'
export default {
computed: {
...mapGetters(['number']),
...fn(['a', 'b', 'c'])
},
mounted () {
this.$store.dispatch('setNumber',10).then(() => {
console.log(this.number)
})
console.log(this.a,this.b,this.c)
}
}
打印結(jié)果為1,2,3
方法getters就類似于vuex中g(shù)etters,
方法fn與vuex中的mapGetters有著相似的功能,其實(shí)在vuex的底層中也是使用這樣類似的原理,這樣看上去是不是簡(jiǎn)單很多。
注:(...)是es6新增語法展開運(yùn)算符,大體有兩個(gè)主要功能,收集參數(shù)與將數(shù)組表達(dá)式或者string在語法層面展開。這里不做過多介紹
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue3+Spring Framework框架開發(fā)實(shí)戰(zhàn)
這篇文章主要為大家介紹了Vue3+Spring Framework框架開發(fā)實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
在Vue3.x中實(shí)現(xiàn)類似React.lazy效果的方法詳解
React 的 React.lazy 功能為組件懶加載提供了原生支持,允許開發(fā)者將組件渲染推遲到實(shí)際需要時(shí)再進(jìn)行,雖然 Vue3.x 沒有一個(gè)直接對(duì)應(yīng)的 lazy 函數(shù),但我們可以通過動(dòng)態(tài)導(dǎo)入和 defineAsyncComponent 方法來實(shí)現(xiàn)類似的效果,需要的朋友可以參考下2024-03-03
淺析Vue3中通過v-model實(shí)現(xiàn)父子組件的雙向數(shù)據(jù)綁定及利用computed簡(jiǎn)化父子組件雙向綁定
這篇文章主要介紹了淺析Vue3中通過v-model實(shí)現(xiàn)父子組件的雙向數(shù)據(jù)綁定及利用computed簡(jiǎn)化父子組件雙向綁定,需要的朋友可以參考下2022-12-12
五步教你用Nginx部署Vue項(xiàng)目及解決動(dòng)態(tài)路由刷新404問題
nginx 是一個(gè)代理的服務(wù)器,下面這篇文章主要給大家介紹了關(guān)于如何通過五步教你用Nginx部署Vue項(xiàng)目及解決動(dòng)態(tài)路由刷新404問題的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12
Vue-cli@3.0 插件系統(tǒng)簡(jiǎn)析
Vue-cli@3.0 是一個(gè)全新的 Vue 項(xiàng)目腳手架。這篇文章主要介紹了Vue-cli@3.0 插件系統(tǒng)簡(jiǎn)析,需要的朋友可以參考下2018-09-09

