vue2中,可以在计算属性中,直接使用mapGetters从vuex中取出多个状态值,Vue3提供了如何获取多个getters中的值,与取state的值类似,只是调用的方法不同,这里使用的是
mapGetters
mapState的使用和封装
mapGetters的hooks封装
封装
目录:src/hooks/useState.js
// useState.js
// useMapper.js
import { useStore, mapGetters } from "vuex";
import { computed } from "vue";
export default function (mapper) {
// 拿到store
const store = useStore();
// 获取相应的对象 : {name:function,gender:function}
const storeStateFns = mapGetters(mapper);
// 进行 $store 指向 ,并赋值
const storeState = {};
Object.keys(storeStateFns).forEach((Fnkey) => {
// setup中无this指向
// 在computed中计算state时需要 $store 指向 ,所以使用bind() 绑定 $store
const fn = storeStateFns[Fnkey].bind({ $store: store });
storeState[Fnkey] = computed(fn);
});
//返回
return storeState;
}
使用
传入数组
<script setup>
import useGetters from '@/hooks/useGetters'
//传入数组
const person = useGetters(['getNameInfo', 'getGenderInfo'])
//返回值是对象
console.log(person.name.value);
</script>
传入对象
<script setup>
import useGetters from '@/hooks/useGetters'
//传入数组
const person = useGetters({
sName:"getNameInfo",
sGende:"getGenderInfo"
})
//返回值是对象
console.log(person.name.value);
</script>
Vue2的用法
<script>
import { mapGetters } from 'vuex';
export default {
computed: {
...mapGetters([
'getNameInfo',
'getGenderInfo'
]),
...mapGetters([
//取值使用键名
sName:"getNameInfo",
sGende:"getGenderInfo"
])
},
};
</script>