这篇文章主要讲解了“Vuex3和Vuex4的区别是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vuex3和Vuex4的区别是什么”吧!
Vuex 是 Vue.js 的官方状态管理库,用于在 Vue.js 应用中管理应用状态。Vuex 3 是用于 Vue 2 的版本,而 Vuex 4 是用于 Vue 3 的版本。下面是 Vuex 3 和 Vuex 4 在一些重要方面的异同点:
Vuex 3:使用 new Vuex.Store()
创建 store 实例
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ // 配置项 }) export default store
Vuex 4:使用 createStore
函数创建 store 实例
import { createStore } from 'vuex' const store = createStore({ // 配置项 }) export default store
Vuex 4 中使用 createStore
函数来创建 store 实例,而不是直接在 Vue 实例上挂载。
Vuex 3:使用 this.$store
访问 store 实例,通过 this.$store.state
访问状态,通过 this.$store.commit()
进行提交 mutation,通过 this.$store.dispatch()
进行分发 action。
export default { computed: { count() { return this.$store.state.count } }, methods: { increment() { this.$store.commit('increment') }, incrementAsync() { this.$store.dispatch('incrementAsync') } } }
Vuex 4:使用 useStore
函数来获取 store 实例,通过 store.state
访问状态,通过 store.commit()
进行提交 mutation,通过 store.dispatch()
进行分发 action。
import { useStore } from 'vuex' export default { setup() { const store = useStore() const count = computed(() => store.state.count) const increment = () => { store.commit('increment') } const incrementAsync = () => { store.dispatch('incrementAsync') } return { count, increment, incrementAsync } } }
虽然 Vuex4 推荐使用更符合 Composition API 风格的 useStore()
来获取 store
实例。但是并没有移除 this.$store
,但是在 <template>
和 Vue2
选项式写法中还是支持使用 $store
的。
Vuex 3:使用 mapState
、mapGetters
、mapMutations
和 mapActions
辅助函数来进行映射,简化在组件中对 store 的访问。
import { mapState, mapGetters, mapMutations, mapActions } from 'vuex' export default { computed: { ...mapState(['count']), ...mapGetters(['doubleCount']), }, methods: { ...mapMutations(['increment']), ...mapActions(['incrementAsync']), } }
Vuex 4:使用 Composition API 中的 computed
函数和普通的 JavaScript 函数来实现类似的功能。
import { computed, useStore } from 'vuex' export default { setup() { const store = useStore() const count = computed(() => store.state.count) const doubleCount = computed(() => store.getters.doubleCount) const increment = () => { store.commit('increment') } const incrementAsync = () => { store.dispatch('incrementAsync') } return { count, doubleCount, increment, incrementAsync } } }
Vuex4 支持选项式写法的辅助函数,在使用时和 Vuex3 一模一样的。但是需要注意辅助函数不能在组合式写法 setup
中使用。
Vuex 3:使用 Vue 2 的响应式系统 ( Object.defineProperty ) 进行状态的监听和更新。
Vuex 4:使用 Vue 3 的响应式系统 ( proxy ) 进行状态的监听和更新,可以利用 Composition API 中的 reactive
和 computed
函数进行更加灵活和高效的状态管理。
实质上这是 Vue2 和 Vue3 的区别,只是由于 Vue 2 匹配的 Vuex 3,Vue 3 匹配的 Vuex 4 的原因,严格来说不能算作 Vuex3 与 Vuex4 的不同。
Vuex 3 是单例模式的,即整个应用只能有一个全局的 Vuex Store 实例。而在 Vuex 4 中,你可以通过 useStore
函数在不同组件中创建多个独立的 Vuex Store 实例,从而支持多例模式。
以下是一个示例展示了如何在 Vuex 4 中使用 useStore
辅助函数创建多个独立的 Vuex Store 实例:
<template> <div> <p>Counter 1: {{ counter1 }}</p> <p>Counter 2: {{ counter2 }}</p> <button @click="incrementCounter1">Increment Counter 1</button> <button @click="incrementCounter2">Increment Counter 2</button> </div> </template> <script> import { useStore } from 'vuex' export default { setup() { // 使用 useStore 辅助函数创建 Vuex Store 实例 const store1 = useStore('store1') const store2 = useStore('store2') // 通过 store1.state.count 获取第一个 Store 的状态 const count1 = store1.state.count // 通过 store2.state.count 获取第二个 Store 的状态 const count2 = store2.state.count // 通过 store1.commit() 提交 mutations 到第一个 Store const incrementCounter1 = () => { store1.commit('increment') } // 通过 store2.commit() 提交 mutations 到第二个 Store const incrementCounter2 = () => { store2.commit('increment') } return { count1, count2, incrementCounter1, incrementCounter2 } } } </script>
上述示例展示了如何在 Vue 组件中使用 useStore
辅助函数创建多个独立的 Vuex Store 实例,并通过这些实例分别访问和修改各自的状态和 mutations。这是 Vuex 4 相对于 Vuex 3 的一个重要的改进,使得 Vuex 在支持多例模式的场景下更加灵活和可扩展。
感谢各位的阅读,以上就是“Vuex3和Vuex4的区别是什么”的内容了,经过本文的学习后,相信大家对Vuex3和Vuex4的区别是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。