<script setup>
import { computed } from 'vue'
import { mapActions, mapGetters, mapMutations, mapState, useStore } from 'vuex'
const store = useStore()
// computed属性结合mapState、mapGetters
const [abc, list] = Object.values(mapState('user', ['abc', 'list'])).map((it) =>
computed(it.bind({ $store: store }))
)
const [getList] = Object.values(mapGetters('user', ['getList'])).map((it) =>
computed(it.bind({ $store: store }))
)
// 不做处理则直接返回bind对应的store方法 mapMutations mapActions
const [incre] = Object.values(mapMutations('user', ['incre'])).map((it) =>
it.bind({ $store: store })
)
const [decre, getUser] = Object.values(
mapActions('user', ['decre', 'getUser'])
).map((it) => it.bind({ $store: store }))
<script>
Vue3.2+setup+js下结合mapState、mapActions、mapGetters、mapMutations使用
本文展示了在Vue组件中如何使用`<scriptsetup>`语法糖来结合Vuex的`mapState`,`mapGetters`,`mapMutations`和`mapActions`。通过`useStore`获取Vuex存储,然后将状态、计算属性、mutation和actions绑定到实例上。
摘要由CSDN通过智能技术生成