当前位置: 首页 > news >正文

【Vue】如何在 Vue 3 中使用组合式 API 与 Vuex 进行状态管理的详细教程

如何在 Vue 3 中使用组合式 API 与 Vuex 进行状态管理的详细教程。

安装 Vuex

首先,在你的 Vue 3 项目中安装 Vuex。可以使用 npm 或 yarn:

npm install vuex@next --save
# or
yarn add vuex@next

创建 Store

在 Vue 3 中,你可以使用 createStore 函数来创建 Vuex Store。通常我们会在项目的 src 目录下创建一个 store 文件夹,并在其中创建一个 index.js 文件:

// src/store/index.jsimport { createStore } from 'vuex';const store = createStore({state() {return {count: 0};},mutations: {increment(state) {state.count++;}},actions: {increment({ commit }) {commit('increment');}},getters: {doubleCount(state) {return state.count * 2;}}
});export default store;

在 Vue 应用中使用 Store

在你的 Vue 应用中,你需要将创建的 Store 实例传递给 Vue 应用。通常在 main.js 文件中进行:

// src/main.jsimport { createApp } from 'vue';
import App from './App.vue';
import store from './store';const app = createApp(App);app.use(store);app.mount('#app');

使用 State

你可以在组合式 API 中通过 useStore 函数来访问 Vuex Store:

<template><div><p>{{ count }}</p></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const count = computed(() => store.state.count);return {count};}
};
</script>

使用 Getters

同样,你可以在组合式 API 中使用 useStore 函数来访问 Vuex Getters:

<template><div><p>{{ doubleCount }}</p></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const doubleCount = computed(() => store.getters.doubleCount);return {doubleCount};}
};
</script>

提交 Mutations

你可以在组合式 API 中通过 useStore 函数来提交 Vuex Mutations:

<template><div><p>{{ count }}</p><button @click="increment">Increment</button></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const count = computed(() => store.state.count);const increment = () => {store.commit('increment');};return {count,increment};}
};
</script>

分发 Actions

你可以在组合式 API 中通过 useStore 函数来分发 Vuex Actions:

<template><div><p>{{ count }}</p><button @click="increment">Increment</button></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const count = computed(() => store.state.count);const increment = () => {store.dispatch('increment');};return {count,increment};}
};
</script>

模块化 Store

当应用变得非常复杂时,可以将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action 和 getter,甚至可以嵌套子模块:

// src/store/index.jsimport { createStore } from 'vuex';const moduleA = {state() {return {count: 0};},mutations: {increment(state) {state.count++;}},actions: {increment({ commit }) {commit('increment');}},getters: {doubleCount(state) {return state.count * 2;}}
};const store = createStore({modules: {a: moduleA}
});export default store;

访问模块中的 State

在组合式 API 中,你可以通过模块名来访问模块中的 state 和其他属性:

<template><div><p>{{ count }}</p></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const count = computed(() => store.state.a.count);return {count};}
};
</script>
http://www.lryc.cn/news/511594.html

相关文章:

  • VSCode 插件开发实战(十五):如何支持多语言
  • 面试241228
  • ​Python数据序列化模块pickle使用
  • Spring Boot对访问密钥加解密——HMAC-SHA256
  • HTML 元素:网页构建的基础
  • HEIC 是什么图片格式?如何把 iPhone 中的 HEIC 转为 JPG?
  • 爆肝1个月:DDR4 的信号完整性(万字长文SI)
  • 前端js验证码插件
  • 关于easy-es对时间范围查询遇到的小bug
  • Mask R-CNN
  • 大模型-Dify使用笔记
  • Suno Api V4模型无水印开发「综合实战开发自己的音乐网站」 —— 「Suno Api系列」第14篇
  • 云原生架构中的中间件容器化:优劣势与实践探索
  • 如何测试模型推理性能:从零开始的Python指南
  • 我们来学activiti -- bpmn
  • 【每日学点鸿蒙知识】节点析构问题、区分手机和pad、 Navigation路由问题、Tabs组件宽度、如何监听Map
  • 敏捷测试文化的转变
  • 如何配置线程池参数,才能创建性能最好、最稳定的Spring异步线程池?
  • 【时间之外】IT人求职和创业应知【80】-特殊日子
  • Vue中接入萤石等直播视频(更新中ing)
  • 如何学习、使用Ai,才能跟上时代的步伐?
  • RabbitMQ中的异步Confirm模式:提升消息可靠性的利器
  • Linux(Centos 7.6)目录结构详解
  • upload-labs关卡记录8
  • GXUOJ-算法-第二次作业
  • Gavin Wood 的 Polkadot 2024 年度回顾:技术突破与未来的无限可能
  • AduSkin、WPF-UI、Prism:WPF 框架全解析与应用指南
  • 【超详细】Git的基本概念和基本使用方式
  • 【数据结构】单链表的使用
  • 外键约束的应用层维护