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

使用Vuex进行状态管理

在Vue.js应用程序中,状态管理是一个重要的主题。当应用程序变得复杂,组件之间的状态共享和通信变得困难,这时候使用Vuex就会变得十分有用。Vuex是一个专门为Vue.js设计的状态管理库,它提供了一个集中式的状态管理方案,使得状态的修改和访问更加直观和可维护。

1.什么是Vuex?

Vuex是一个专门为Vue.js应用程序开发的状态管理库。它借鉴了Flux和Redux的概念,采用了集中式的状态管理架构。Vuex的核心概念包括状态(State)、Mutation、Action和Getter。

  • 状态(State):应用程序中的数据源,通常通过Vuex的state对象来表示。我们可以在组件中直接访问和使用状态,而不需要手动进行组件之间的传递。

  • Mutation:用于修改状态的方法,类似于事件。每个Mutation都有一个字符串类型的事件类型和一个回调函数,在回调函数中进行状态的修改。Mutations应该是同步的操作。

  • Action:用于处理异步操作和复杂的业务逻辑。Action提交Mutations来修改状态。它可以包含任意异步操作,如HTTP请求、定时器等。Actions是异步的操作。

  • Getter:类似于组件的计算属性,用于从状态中派生出新的数据。Getter的返回值会根据它的依赖被缓存起来,只有当依赖发生改变时才会重新计算。

 

2.如何使用Vuex? 

使用Vuex进行状态管理需要以下几个步骤

1. 安装和配置Vuex

首先,在你的Vue.js项目中安装Vuex。可以通过npm或yarn来进行安装

npm install vuex  //默认安装最新版本npm install vuex@3.0.0  //指定版本

安装完成后,在你的主应用程序文件中导入Vuex,并使用Vue.use()来启用它

//创建store文件夹,新建一个index.js文件作为主文件,以便后续进行vuex模块区分import Vue from 'vue'
import Vuex from 'vuex'Vue.use(Vuex)

然后,创建一个新的Vuex实例,并导出它供应用程序使用

//store.js文件export default new Vuex.Store({// 状态、Mutations、Actions和Getters在这里定义
})

与vue-router类似,将Store实例在mian.js中挂载.

 

2. 定义状态(State)

在Vuex实例中,你可以定义应用程序的状态。状态可以是任何JavaScript对象,包含应用程序中需要共享的数据

export default new Vuex.Store({state: {count: 0,todos: []}
})

我们也可以进行模块化,状态和数据复杂的时候,方便管理

 在tab.js中,注意在Vuex主模块中引入文件

 获取state中的数据

 computed: {count() {return this.$store.state.count},todos() {return this.$store.state.todos}

如果是采用模块化的

 computed: {count() {return this.$store.state.tab.count},todos() {return this.$store.state.tab.todos}

 

mapState 辅助函数

当一个组件需要获取多个状态的时候,将这些状态都声明为计算属性会有些重复和冗余。我们就要使用到mapState辅助函数

 computed: {...mapState(['count', 'todos'])}

我们首先从vuex中导入了mapState辅助函数。然后,在computed选项中,使用展开运算符(...)和mapState函数来将counttodos映射为组件的计算属性。

这样,我们可以直接在模板中使用counttodos,而不需要使用this.$store.state.countthis.$store.state.todos来获取状态。

 computed: {...mapState('tab', ['count']),...mapState('tab', ['todos'])}

注意,在使用模块化的状态时,我们需要在mapState函数的第一个参数中指定对应的模块名称。

例如,...mapState("tab", ["count"])表示将counter模块中的count状态映射为count计算属性。

3. 定义Mutations

定义Mutations来修改状态。每个Mutation都有一个字符串类型的事件类型和一个回调函数,在回调函数中进行状态的修改

export default new Vuex.Store({
state: {count: 0,todos: []
},
mutations: {increment(state) {state.count++},addTodo(state, todo) {state.todos.push(todo)}
}
})

 

4. 调用Mutations

在组件中,你可以使用`this.$store.commit()`方法来调用Mutations并修改状态

 methods: {increment() {this.$store.commit('increment')},addTodo() {this.$store.commit('addTodo', { id: Date.now(), text: this.newTodoText })this.newTodoText = ''}}

模块化的方法

 methods: {increment() {this.$store.commit('tab/increment')},addTodo() {this.$store.commit('tab/addTodo', { id: Date.now(), text: this.newTodoText })this.newTodoText = ''}}

 mapMutations辅助函数

 methods: {...mapMutations(['increment']),add(){this.increment(参数)}}

methods选项中,使用mapMutations函数将increment Mutations映射为组件的方法。这样,我们可以直接在组件中调用increment方法,而无需使用this.$store.commit("increment")来提交Mutations。

如果你想给映射的Mutations方法起一个不同于Mutations名称的方法名,可以使用对象形式的映射

methods: {...mapMutations({increase: 'increment'}),add(){this.increase(参数)}}

模块化方法

methods: {...mapMutations('tab', ['increment'])}

 注意使用辅助函数需要在组件引用

 

5. 定义Actions

Actions用于处理异步操作和复杂的业务逻辑。它提交Mutations来修改状态。在Actions中可以包含任意异步操作,如HTTP请求、定时器等

export default new Vuex.Store({state: {count: 0,todos: []},mutations: {increment(state) {state.count++},addTodo(state, todo) {state.todos.push(todo)}},actions: {incrementAsync(context) {setTimeout(() => {context.commit('increment')}, 1000)}}
})

 

6. 调用Actions

在组件中,你可以使用this.$store.dispatch()方法来调用Actions

this.$store.dispatch('incrementAsync')

 

7. 定义Getters

Getters用于从状态中派生出新的数据,类似于组件的计算属性。Getter的返回值会根据它的依赖被缓存起来,只有当依赖发生改变时才会重新计算

export default new Vuex.Store({state: {todos: [{ id: 1, text: 'Buy groceries', completed: false },{ id: 2, text: 'Do laundry', completed: true }]},getters: {completedTodos(state) {return state.todos.filter(todo => todo.completed)},incompleteTodos(state) {return state.todos.filter(todo => !todo.completed)}}
})

在组件中,你可以使用this.$store.getters来访问Getter的值

computed: {completedTodos() {return this.$store.getters.completedTodos}
}

相关文章:

使用Vuex进行状态管理

在Vue.js应用程序中,状态管理是一个重要的主题。当应用程序变得复杂,组件之间的状态共享和通信变得困难,这时候使用Vuex就会变得十分有用。Vuex是一个专门为Vue.js设计的状态管理库,它提供了一个集中式的状态管理方案,…...

【优化调度】基于改进遗传算法的公交车调度排班优化的研究与实现(Matlab代码实现)

目录 1 概述 2 运行结果 3 参考文献 4 Matlab代码 1 概述 本文对当前公交企业调度系统进行了分析,建立了公交排班的数学模型。本文基于数据挖掘分析的结果上,使用截面客流量数据对模型进行约束,得出了公交客流出行的空间分布规律。再以…...

IMX6ULL裸机篇之I2C实验-硬件原理图

一. I2C 实验简介 I2C实验,我们就来学习如何使用 I.MX6U 的 I2C 接口来驱动 AP3216C,读取 AP3216C 的传感器数据。 AP3216C是一个三合一的环境光传感器,ALSPSIRLED,ALS是环境光,PS是接近传感器,IR是红外L…...

华为OD机试真题 Java 实现【获取字符串中连续出现次数第k多的字母的次数】【2023Q1 100分】,附详细解题思路

一、题目描述 给定一个字符串&#xff0c;只包含大写字母&#xff0c;求在包含同一字母的子串中&#xff0c;长度第 k 长的子串的长度&#xff0c;相同字母只取最长的那个子串。 二、输入描述 第一行有一个子串(1<长度<100)&#xff0c;只包含大写字母&#xff1b;第二…...

充分统计量和因子分解定理

充分统计量 定义&#xff1a; 设样本 X X X的服从分布 f ( X ∣ θ ) f(X|\theta) f(X∣θ)&#xff0c; θ ∈ Θ \theta\in\Theta θ∈Θ&#xff0c;设 T T ( X ) TT(X) TT(X)为一统计量&#xff0c;若在已知 T T T的条件下&#xff0c;样本 X X X的条件分布与参数 θ \the…...

M1 PD安装arm ubuntu及Docker

M1 PD安装arm ubuntu 下载 Ubuntu 22.04.2 LTS https://cn.ubuntu.com/download/server/arm 参考视频安装 https://www.bilibili.com/video/BV1Mu4y1f74v/?spm_id_from333.999.0.0&vd_source9056c6d3c91a117baaceb663957daa08 PD Ubuntu安装docker 删除现有的docker安装…...

TCP协议的RST标志

下文中的内容多数来自【参考】中的文章&#xff0c;这边进行一个整理和总结&#xff0c;后续会慢慢增加出现各个 RST 包的测试代码&#xff0c;便于理解。 TCP的 “断开连接” 标志 RST 标志 Reset&#xff0c;复位标志&#xff0c;用于非正常地关闭连接。它是 TCP 协议首部里…...

【软件质量与软件测试 白盒测试与黑盒测试】

第十章 黑盒测试 10.1 等价类划分&#xff1a; 10.1.1 划分等价类 等价类是指所有数据中的一组&#xff0c;它们具有相同的测试结果或相同的响应。等价类划分是将输入数据分为多个等价类的过程。 10.1.2 划分等价类的方法 划分等价类方法主要包括以下几种&#xff1a; 特…...

JavaScript教程(高级)

面向对象编程介绍 两大编程思想 &#xff08;1&#xff09;、 面向过程编程&#xff1a; &#xff08;缩写 POP&#xff09;&#xff08; Process-oriented programming&#xff09;面向过程就是分析出解决问题所需要的步骤&#xff0c;然后用函数把这些步骤一步一步实现&am…...

C++进阶 —— 范围for(C++11新特性)

目录 一&#xff0c;范围for介绍 二&#xff0c;范围for注意事项 一&#xff0c;范围for介绍 范围for&#xff08;range-based for loop&#xff09;是C11新引入的特性&#xff0c;可遍历各种序列结构的容器&#xff08;如数组、vector、list等&#xff09;&#xff1b;每次循…...

ELK +Filebeat日志分析系统

一、 ELK日志分析系统概述 1、ELK简介 ELK是三个开源软件的缩写&#xff0c;分别表示&#xff1a;Elasticsearch , Logstash, Kibana , 它们都是开源软件。新增了一个FileBeat&#xff0c;它是一个轻量级的日志收集处理工具(Agent)&#xff0c;Filebeat占用资源少&#xff0c…...

万字解析PELT算法!

Linux是一个通用操作系统的内核&#xff0c;她的目标是星辰大海&#xff0c;上到网络服务器&#xff0c;下至嵌入式设备都能运行良好。做一款好的linux进程调度器是一项非常具有挑战性的任务&#xff0c;因为设计约束太多了&#xff1a; 它必须是公平的快速响应系统的throughp…...

腾讯云服务器端口怎么全开?教程来了

腾讯云服务器端口怎么全开&#xff1f;云服务器CVM在安全组中设置开通&#xff0c;轻量应用服务器在防火墙中设置&#xff0c;腾讯云百科来详细说下腾讯云服务器端口全开放教程&#xff1a; 目录 腾讯云服务器端口全部开通教程 云服务器CVM端口全开放教程 轻量应用服务器开…...

深入理解Java虚拟机:JVM高级特性与最佳实践-总结-13

深入理解Java虚拟机&#xff1a;JVM高级特性与最佳实践-总结-13 Java内存模型与线程Java内存模型原子性、可见性与有序性先行发生原则 Java内存模型与线程 Java内存模型 原子性、可见性与有序性 Java内存模型是围绕着在并发过程中如何处理原子性、可见性和有序性这三个特征来…...

租售keysight E8257D 50G模拟信号发生器 销售/回收

是德&#xff08;Keysight&#xff09; E8257D 模拟信号发生器 Keysight E8257D (Agilent) PSG 模拟信号发生器提供业界领先的输出功率、电平精度和高达 67 GHz 的相位噪声性能&#xff08;工作频率可达 70 GHz&#xff09;。Agilent PSG 模拟信号发生器的高输出功率和卓越的电…...

【C++】什么是函数模板/类模板?

文章目录 一、函数模板1.什么是函数模板&#xff1f;2.函数模板格式3.函数模板原理4.函数模板实例化&#xff08;1&#xff09;隐式实例化&#xff08;2&#xff09;显示实例化 二.类模板1.类模板定义格式2.类模板的实例化 总结 一、函数模板 1.什么是函数模板&#xff1f; 函…...

为什么是ChatGPT引发了AI浪潮?

目录 BERT和GPT简介 BERT和GPT核心差异 GPT的优势 GPT的劣势 总结 随着近期ChatGPT的火热&#xff0c;引发各行各业都开始讨论AI&#xff0c;以及AI可以如何应用到各个细分场景。为了不被时代“抛弃”&#xff0c;我也投入了相当的精力用于研究和探索。但在试验的过程中&…...

批处理文件(.bat)启动redis及任何软件(同理)

批处理文件 每次从文件根目录用配置文件格式来启动redis太麻烦了 可以在桌面上使用批处理文件&#xff08;.bat&#xff09;启动Redis&#xff0c;请按照以下步骤进行操作&#xff1a; 打开文本编辑器&#xff0c;如记事本。 在编辑器中输入以下内容&#xff1a; 将文件保存…...

深度学习求解稀疏最优控制问题的并行化算法

稀疏最优控制问题 问题改编自论文An FE-Inexact Heterogeneous ADMM for Elliptic Optimal Control Problems with L1-Control Cost { min ⁡ y ( μ ) , u ( μ )...

牛客网项目—开发社区首页

视频连接&#xff1a;开发社区首页_哔哩哔哩_bilibili 代码地址&#xff1a;Community: msf begin 仿牛客论坛项目 (gitee.com) 本文是对仿牛客论坛项目的学习&#xff0c;学习本文之前需要了解Java开发的常用框架&#xff0c;例如SpringBoot、Mybatis等等。如果你也在学习牛…...

XCTF-web-easyupload

试了试php&#xff0c;php7&#xff0c;pht&#xff0c;phtml等&#xff0c;都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接&#xff0c;得到flag...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候&#xff0c;难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵&#xff0c;或者买了二手 iPhone 却被原来的 iCloud 账号锁住&#xff0c;这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

Keil 中设置 STM32 Flash 和 RAM 地址详解

文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全&#xff1a;零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言&#xff1a;云原生安全的范式革命 随着云原生技术的普及&#xff0c;安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测&#xff0c;到2025年&#xff0c;零信任架构将成为超…...

【单片机期末】单片机系统设计

主要内容&#xff1a;系统状态机&#xff0c;系统时基&#xff0c;系统需求分析&#xff0c;系统构建&#xff0c;系统状态流图 一、题目要求 二、绘制系统状态流图 题目&#xff1a;根据上述描述绘制系统状态流图&#xff0c;注明状态转移条件及方向。 三、利用定时器产生时…...

CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云

目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...

ios苹果系统,js 滑动屏幕、锚定无效

现象&#xff1a;window.addEventListener监听touch无效&#xff0c;划不动屏幕&#xff0c;但是代码逻辑都有执行到。 scrollIntoView也无效。 原因&#xff1a;这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作&#xff0c;从而会影响…...

OpenLayers 分屏对比(地图联动)

注&#xff1a;当前使用的是 ol 5.3.0 版本&#xff0c;天地图使用的key请到天地图官网申请&#xff0c;并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能&#xff0c;和卷帘图层不一样的是&#xff0c;分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...

LeetCode - 199. 二叉树的右视图

题目 199. 二叉树的右视图 - 力扣&#xff08;LeetCode&#xff09; 思路 右视图是指从树的右侧看&#xff0c;对于每一层&#xff0c;只能看到该层最右边的节点。实现思路是&#xff1a; 使用深度优先搜索(DFS)按照"根-右-左"的顺序遍历树记录每个节点的深度对于…...

【从零学习JVM|第三篇】类的生命周期(高频面试题)

前言&#xff1a; 在Java编程中&#xff0c;类的生命周期是指类从被加载到内存中开始&#xff0c;到被卸载出内存为止的整个过程。了解类的生命周期对于理解Java程序的运行机制以及性能优化非常重要。本文会深入探寻类的生命周期&#xff0c;让读者对此有深刻印象。 目录 ​…...