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

Vue3之状态管理Vuex

Vuex作为Vue.js的官方状态管理库,在大型或复杂的前端项目中扮演着至关重要的角色。本文将从Vuex的原理、特点、应用场景等多个方面进行深入解析,并通过代码示例展示如何在Vuex中实现特定功能。

一、Vuex原理

Vuex是一个专为Vue.js应用程序开发的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex的核心概念包括state、getters、mutations、actions和modules,这些概念共同构成了一个完整的状态管理框架。

1.1 State(状态)

State是Vuex中的单一状态树,即用一个对象就包含了全部的应用层级状态。它是不可变的,只能通过提交mutations来修改。在Vue组件中,可以通过this.$store.state来访问状态。

1.2 Getters(获取器)

Getters可以认为是store的计算属性,就像组件中的计算属性一样,getters的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。通过getters,可以方便地派生出一些状态,或对数据进行进一步的处理。

1.3 Mutations(变更)

Mutations是Vuex中唯一可以修改state的方法。每个mutation都有一个字符串的事件类型(type)和一个回调函数(handler)。这个回调函数是实际进行状态更改的地方,并且它会接受state作为第一个参数。需要注意的是,mutation必须是同步函数。

1.4 Actions(动作)

Actions类似于mutations,但它们主要用于处理异步操作。Actions可以包含任意异步操作,并在操作完成后提交mutations来修改state。通过actions,我们可以进行异步操作或复杂逻辑的提交,然后调用mutation来变更状态。

1.5 Modules(模块)

当项目比较大时,状态会集中,从而导致项目臃肿。Vuex允许将store分割成模块(module)。每个模块拥有自己的state、mutation、action、getter,甚至是嵌套子模块。这使得状态管理更加模块化和清晰。

二、Vuex特点

Vuex作为Vue.js的状态管理库,具有以下显著特点:

2.1 集中式状态管理

Vuex将应用的状态集中存储在一个单一的状态树中。这样可以方便地管理和追踪状态的变化,避免了状态分散在多个组件中导致的混乱和难以维护的问题。

2.2 组件之间共享状态

在大型应用中,多个组件可能需要共享某些状态,例如用户登录状态、购物车数量等。Vuex提供了一个中央存储库,使得多个组件可以方便地访问和修改共享状态。

2.3 状态的可追踪和可维护性

Vuex使用了响应式的状态管理,当状态发生变化时,相关的组件会自动更新。同时,Vuex提供了一些工具来追踪状态的变化,例如通过插件可以记录每个mutation的变更历史。这样可以更好地追踪和调试状态的变化。

2.4 简化组件通信

在Vue.js中,组件之间的通信可以通过props和事件来实现。但是当应用变得复杂时,组件之间的通信会变得困难和混乱。Vuex提供了一种集中式的数据流模式,使得组件之间的通信更加直观和可控。

三、Vuex应用场景

Vuex适用于多种应用场景,特别是在大型或复杂的前端项目中,其优势更加明显。以下是一些常见的应用场景:

3.1 管理大型应用的状态

在大型应用中,状态管理变得非常复杂。使用Vuex可以集中管理应用的所有状态,使得状态管理和共享变得更加简单和一致。

3.2 方便的状态共享

当多个组件需要共享状态时,使用Vuex可以方便地实现状态共享。例如,用户登录状态、购物车数量等全局状态都可以通过Vuex进行集中管理。

3.3 调试工具支持

Vuex与Vue Devtools无缝集成,提供了强大的调试工具。开发者可以使用Vue Devtools来追踪状态的变化、查看状态的历史记录等,从而更方便地进行调试和问题排查。

3.4 异步操作处理

Vuex的actions支持异步操作,可以方便地处理异步数据请求。通过actions,我们可以在异步操作完成后提交mutations来修改state,从而实现异步状态管理。

3.5 模块化管理

当项目比较大时,状态会集中,从而导致项目臃肿。Vuex允许将store分割成模块(module),每个模块拥有自己的state、mutation、action、getter等。这使得状态管理更加模块化和清晰。

四、代码示例

下面通过一个具体的代码示例来展示如何在Vuex中实现特定功能。

4.1 示例背景

假设我们正在开发一个购物车应用,该应用包含商品列表、购物车和用户个人信息等多个组件。我们需要使用Vuex来管理这些组件之间的共享状态。

4.2 创建Vuex Store

首先,我们需要在Vuex中定义一个状态树来存储所有需要共享的状态,如商品列表、购物车和用户个人信息等。然后,在Vue组件中通过this.$store.statethis.$store.getters等方式访问这些状态。

// store/index.js
import { createStore } from 'vuex'export default createStore({state: {cart: [],  // 购物车商品列表userInfo: {  // 用户个人信息name: '',email: ''}},mutations: {// 添加商品到购物车ADD_TO_CART(state, product) {const existItem = state.cart.find(item => item.id === product.id)if (existItem) {existItem.quantity += 1} else {state.cart.push({ ...product, quantity: 1 })}},// 从购物车中移除商品REMOVE_FROM_CART(state, productId) {state.cart = state.cart.filter(item => item.id !== productId)},// 更新用户信息UPDATE_USER_INFO(state, payload) {state.userInfo = { ...state.userInfo, ...payload }}},actions: {// 异步操作:从服务器获取用户信息并更新到store中fetchUserInfo({ commit }) {// 假设这里有一个异步请求获取用户信息setTimeout(() => {const userInfo = {name: 'John Doe',email: 'john.doe@example.com'}commit('UPDATE_USER_INFO', userInfo)}, 1000)}},getters: {// 获取购物车中商品的总数量cartItemCount: state => {return state.cart.reduce((total, item) => total + item.quantity, 0)},// 获取购物车中商品的总价格cartTotalPrice: state => {return state.cart.reduce((total, item) => total + item.price * item.quantity, 0)}}
})

4.3 在Vue组件中使用Vuex

接下来,我们需要在Vue组件中通过this.$store.statethis.$store.gettersthis.$store.committhis.$store.dispatch等方式访问和修改状态。

4.3.1 商品列表组件

商品列表组件用于展示商品列表,并提供将商品添加到购物车的功能。

<!-- src/components/ProductList.vue -->
<template><div><h1>商品列表</h1><ul><li v-for="product in products" :key="product.id">{{ product.name }} - ¥{{ product.price }}<button @click="addToCart(product)">添加到购物车</button></li></ul></div>
</template><script>
export default {data() {return {products: [{ id: 1, name: '商品A', price: 100 },{ id: 2, name: '商品B', price: 200 },{ id: 3, name: '商品C', price: 300 }]}},methods: {addToCart(product) {this.$store.commit('ADD_TO_CART', product)}}
}
</script>

4.3.2 购物车组件

购物车组件用于展示购物车中的商品列表,并提供移除商品的功能。

<!-- src/components/Cart.vue -->
<template><div><h1>购物车</h1><ul><li v-for="item in cartItems" :key="item.id">{{ item.name }} - ¥{{ item.price }} × {{ item.quantity }}<button @click="removeFromCart(item.id)">移除</button></li></ul><p>总数量: {{ cartItemCount }}</p><p>总价格: ¥{{ cartTotalPrice.toFixed(2) }}</p></div>
</template><script>
export default {computed: {cartItems() {return this.$store.state.cart;},cartItemCount() {return this.$store.getters.cartItemCount;},cartTotalPrice() {return this.$store.getters.cartTotalPrice;}},methods: {removeFromCart(productId) {this.$store.commit('REMOVE_FROM_CART', productId);}}
}
</script>

4.4 用户信息组件

用户信息组件用于展示和更新用户个人信息。

<!-- src/components/UserInfo.vue -->
<template><div><h1>用户信息</h1><p>姓名: {{ userInfo.name }}</p><p>邮箱: {{ userInfo.email }}</p><button @click="fetchUserInfo">更新用户信息</button></div>
</template><script>
export default {computed: {userInfo() {return this.$store.state.userInfo;}},methods: {fetchUserInfo() {this.$store.dispatch('fetchUserInfo');}}
}
</script>

4.5 将Vuex Store注入到Vue应用中

最后,我们需要在Vue应用的入口文件中将Vuex Store注入到Vue实例中,这样我们就可以在所有的Vue组件中通过this.$store来访问和操作Store了。

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

4.6 说明

通过以上步骤,我们成功地在Vuex中实现了购物车应用的状态管理。我们定义了共享的状态树,创建了用于修改状态的mutations和用于异步操作的actions,还定义了方便获取状态的getters。然后,我们在Vue组件中通过this.$store来访问和修改这些状态,实现了组件之间的数据共享和通信。这种集中式状态管理的方式使得我们的应用更加易于维护和扩展。

五、总结

Vuex作为Vue.js的官方状态管理库,为大型或复杂前端项目提供了高效的解决方案。它通过集中式存储管理应用状态,确保状态变化可预测。Vuex的核心包括state、getters、mutations、actions和modules,分别负责状态存储、状态派生、状态修改、异步操作和模块化管理。其特点在于集中式状态管理、组件间状态共享、状态可追踪维护以及简化组件通信。在购物车应用实例中,我们展示了如何在Vuex中定义状态树、创建mutations和actions、定义getters,并在Vue组件中访问和修改状态,实现了组件间的数据共享和通信。Vuex的应用极大地提升了应用的维护性和扩展性,是Vue.js开发中不可或缺的工具。

相关文章:

Vue3之状态管理Vuex

Vuex作为Vue.js的官方状态管理库&#xff0c;在大型或复杂的前端项目中扮演着至关重要的角色。本文将从Vuex的原理、特点、应用场景等多个方面进行深入解析&#xff0c;并通过代码示例展示如何在Vuex中实现特定功能。 一、Vuex原理 Vuex是一个专为Vue.js应用程序开发的状态管…...

DPO(Direct Preference Optimization)算法解释:中英双语

中文版 DPO paper: https://arxiv.org/pdf/2305.18290 DPO 算法详解&#xff1a;从理论到实现 1. 什么是 DPO&#xff1f; DPO&#xff08;Direct Preference Optimization&#xff09;是一种直接基于人类偏好进行优化的算法&#xff0c;旨在解决从人类偏好数据中训练出表现…...

Hostapd2.11解析笔记

最近在调试Hostapd,尝试通过配置使能一个支持MLO的AP,不过不知道hostapd conf里面哪些选项开启后可以使能,所以对Hostapd做一个整体解析. 简介 hostapd 是用于接入点和身份验证服务器的用户空间守护程序。它实现 IEEE 802.11 接入点管理、IEEE 802.1X/WPA/WPA2/WPA3/EAP 身份…...

js控制文字溢出显示省略号

.text{display: -webkit-box;overflow: hidden;white-space: normal;text-overflow: ellipsis;word-wrap: break-word;-webkit-line-clamp: 2;-webkit-box-orient: vertical; }本人有个需求就是在一个盒子内有一段文本&#xff0c;然后控制文本显示两行&#xff0c;第二行要显示…...

WPF+MVVM案例实战与特效(四十七)-实现一个路径绘图的自定义按钮控件

文章目录 1、案例效果2、创建自定义 PathButton 控件1、定义 PathButton 类2、设计样式与控件模板3、代码解释3、控件使用4、直接在 XAML 中绑定命令3、源代码获取4、总结1、案例效果 2、创建自定义 PathButton 控件 1、定义 PathButton 类 首先,我们需要创建一个新的类 Pat…...

操作002:HelloWorld

文章目录 操作002&#xff1a;HelloWorld一、目标二、具体操作1、创建Java工程①消息发送端&#xff08;生产者&#xff09;②消息接收端&#xff08;消费者&#xff09;③添加依赖 2、发送消息①Java代码②查看效果 3、接收消息①Java代码②控制台打印③查看后台管理界面 操作…...

odoo中@api.model, @api.depends和@api.onchange 装饰器的区别

文章目录 1. api.model用途特点示例 2. api.depends用途特点示例 3. api.onchange用途特点示例 总结 在 Odoo 中&#xff0c;装饰器&#xff08;decorators&#xff09;用于修饰方法&#xff0c;以指定它们的行为和触发条件。api.model、api.depends 和 api.onchange 是三个常用…...

有哪些精益工具可以帮助企业实现转型?

为了在激烈的市场竞争中立于不败之地&#xff0c;许多企业开始寻求通过精益转型来优化运营、降低成本、提高效率和客户满意度。然而&#xff0c;精益转型并非一蹴而就&#xff0c;而是需要一系列精益工具的辅助&#xff0c;这些工具能够帮助企业识别浪费、优化流程、提升质量&a…...

以太网帧结构

以太网帧结构 目前&#xff0c;我们局域网当中应用最广的技术或者协议啊&#xff0c;就是以太网。我们首先来看一下以太网的真结构。这块内容这里边再系统的来给大家去展开说一下&#xff0c;以太网真格式就如下面这个图。所示前面有八个字节&#xff0c;是用于时钟同步的&…...

QT调用Sqlite数据库

QT设计UI界面&#xff0c;后台访问数据库&#xff0c;实现数据库数据的增删改查。 零售商店系统 数据库表&#xff1a; 分别是顾客表&#xff0c;订单详情表&#xff0c;订单表&#xff0c;商品表 表内字段详情如下&#xff1a; 在QT的Pro文件中添加sql&#xff0c;然后添加头…...

前端

前端页面 Web页面 PC端程序页面 移动端APP页面 ... HTML页面 HTML超文本标记页面 超文本&#xff1a;文本&#xff0c;声音&#xff0c;图片&#xff0c;视频&#xff0c;表格&#xff0c;链接 标记&#xff1a;由许多标签组成 HTML页面运行到浏览器上面 vscode便捷插件使用 vs…...

【Git】—— 使用git操作远程仓库(gitee)

目录 一、远程仓库常用命令 1、从远程仓库克隆项目 2、查看关联的远程仓库 3、添加关联的远程仓库 4、移除关联的远程仓库 5、将本地仓库推送到远程仓库 6、从远程仓库拉取项目 二、分支命令 1、查询分支 2、创建分支 3、切换分支 4、推送到远程分支 5、合并分支 …...

Paddler负载均衡器

Paddler负载均衡器 Paddler本身是用Go语言编写的,没有直接的Python接口,但可以通过以下方式在Python中使用: 执行命令行调用 在Python中可以使用 subprocess 模块来调用Paddler的命令行工具,实现负载均衡功能 。例如: import subprocessdef start_paddler_agent():com…...

OSCP - Proving Grounds - Slort

主要知识点 文件包含 windows的reveseshell 具体步骤 执行nmap,依旧是很多端口开放&#xff0c;尝试了ftp,smb等均失败 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-10-13 12:00 UTC Nmap scan report for 192.168.53.53 Host is up (0.00095s latency). Not sho…...

YoloV9改进策略:Head改进|DynamicHead,利用注意力机制统一目标检测头部|即插即用

摘要 论文介绍 本文介绍了一种名为DynamicHead的模块,该模块旨在通过注意力机制统一目标检测头部,以提升目标检测的性能。论文详细阐述了DynamicHead的工作原理,并通过实验证明了其在COCO基准测试上的有效性和效率。 创新点 DynamicHead模块的创新之处在于它首次尝试在一…...

BFD综合详细实验配置案例

前言 本实验的目的是通过配置BGP&#xff08;边界网关协议&#xff09;、OSPF&#xff08;开放式最短路径优先协议&#xff09;、VRRP&#xff08;虚拟路由冗余协议&#xff09;以及BFD&#xff08;双向转发检测&#xff09;等网络协议&#xff0c;模拟企业级网络环境中的多协…...

自然语言处理与知识图谱的融合与应用

目录 前言1. 知识图谱与自然语言处理的关系1.1 知识图谱的定义与特点1.2 自然语言处理的核心任务1.3 二者的互补性 2. NLP在知识图谱构建中的应用2.1 信息抽取2.1.1 实体识别2.1.2 关系抽取2.1.3 属性抽取 2.2 知识融合2.3 知识推理 3. NLP与知识图谱融合的实际应用3.1 智能问答…...

c# RSA加解密工具,.netRSA加解密工具

软件介绍 名称: c# RSA加解密工具,.netRSA加解密工具依赖.net版本: .net 8.0工具类型: WinForm源码下载 c# RSA加解密工具,.netRSA加解密工具 依赖项 WinFormsRSA.csproj <Project...

Metricbeat安装教程——Linux——Metricbeat监控ES集群

Metricbeat安装教程——Linux 一、安装 下载安装包&#xff1a; 官网下载地址&#xff1a;https://www.elastic.co/cn/downloads/beats/metricbeat 上传包到linux 切换到安装目录下 解压&#xff1a;tar -zxvf metricbeat-7.17.1-linux-x86_64.tar.gz 重命名安装文件夹 mv met…...

一万多字拆解java中——“ 注解 ”的一切(三)(已完结)

前言&#xff1a; 咱们书接上回&#xff0c;上次按照框架讲了 第一篇&#xff0c;我们讲到了&#xff1a; ①注解的引入&#xff08;简单概述&#xff09;&#xff1a;在jdk5.0的时候 ②注解与注释的区别&#xff1a; 注释 是为了帮助人类阅读代码&#xff0c;不会对程序的执…...

挑战杯推荐项目

“人工智能”创意赛 - 智能艺术创作助手&#xff1a;借助大模型技术&#xff0c;开发能根据用户输入的主题、风格等要求&#xff0c;生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用&#xff0c;帮助艺术家和创意爱好者激发创意、提高创作效率。 ​ - 个性化梦境…...

大数据学习栈记——Neo4j的安装与使用

本文介绍图数据库Neofj的安装与使用&#xff0c;操作系统&#xff1a;Ubuntu24.04&#xff0c;Neofj版本&#xff1a;2025.04.0。 Apt安装 Neofj可以进行官网安装&#xff1a;Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...

docker详细操作--未完待续

docker介绍 docker官网: Docker&#xff1a;加速容器应用程序开发 harbor官网&#xff1a;Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台&#xff0c;用于将应用程序及其依赖项&#xff08;如库、运行时环…...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…...

Spring Boot 实现流式响应(兼容 2.7.x)

在实际开发中&#xff0c;我们可能会遇到一些流式数据处理的场景&#xff0c;比如接收来自上游接口的 Server-Sent Events&#xff08;SSE&#xff09; 或 流式 JSON 内容&#xff0c;并将其原样中转给前端页面或客户端。这种情况下&#xff0c;传统的 RestTemplate 缓存机制会…...

Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件

今天呢&#xff0c;博主的学习进度也是步入了Java Mybatis 框架&#xff0c;目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学&#xff0c;希望能对大家有所帮助&#xff0c;也特别欢迎大家指点不足之处&#xff0c;小生很乐意接受正确的建议&…...

Psychopy音频的使用

Psychopy音频的使用 本文主要解决以下问题&#xff1a; 指定音频引擎与设备&#xff1b;播放音频文件 本文所使用的环境&#xff1a; Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...

精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南

精益数据分析&#xff08;97/126&#xff09;&#xff1a;邮件营销与用户参与度的关键指标优化指南 在数字化营销时代&#xff0c;邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天&#xff0c;我们将深入解析邮件打开率、网站可用性、页面参与时…...

今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存

文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...

初探Service服务发现机制

1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能&#xff1a;服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源&#xf…...