30、Vuex 为啥可以进行缓存处理

news2025/3/18 18:48:31
  1. Vuex 状态管理基础与缓存的关联

    • Vuex 的核心概念

      • Vuex 主要由五个部分组成:statemutationsactionsgettersmodules。其中,state是存储数据的地方,类似于一个全局的数据仓库。在这个菜谱 APP 的例子中,缓存的数据就存储在state中。
      • 例如,我们可以在state中定义一个对象来存储菜谱品类和菜谱的数据,像这样:

        javascript

        const state = {
          recipeCache: {}
        };
        

        这里的recipeCache就是用来缓存菜谱相关数据的对象,以品类下标作为键,对应的菜谱数据作为值。
    • 组件与 Vuex 数据的交互

      • 组件可以通过mapStatemapGetters等辅助函数来获取state中的数据。这样,不同的组件(如左边的菜谱品类展示组件和右边的菜谱展示组件)都能够访问和使用存储在state中的缓存数据。
      • 比如,在一个组件中,我们可以这样获取缓存的菜谱数据:

        javascript

        import { mapState } from 'vuex';
        export default {
          computed: {
           ...mapState(['recipeCache'])
          }
        };
        

        这使得组件能够方便地获取recipeCache中的数据,并根据这些数据进行渲染。
  2. 缓存处理的具体实现与优势

    • 减少接口调用次数

      • 最初,每次切换菜谱品类时,都会调用接口获取数据。有了 Vuex 缓存后,在获取数据之前,可以先检查state中的recipeCache对象是否已经存在对应的品类数据。
      • 例如,有一个方法用于获取菜谱数据,改造后的代码可能如下:

        javascript

        async getRecipeData(categoryIndex) {
          if (this.$store.state.recipeCache[categoryIndex]) {
            return this.$store.state.recipeCache[categoryIndex];
          }
          // 如果缓存中没有数据,则调用接口获取
          const data = await api.getRecipeData(categoryIndex);
          this.$store.commit('setRecipeData', { categoryIndex, data });
          return data;
        }
        

        这里通过判断recipeCache中是否存在数据来决定是否调用接口,从而避免了不必要的接口调用,减少了性能消耗。
    • 数据共享与一致性

      • 由于 Vuex 的state是全局共享的,多个组件可以访问相同的缓存数据。这确保了整个应用中菜谱数据的一致性。
      • 比如,左边的菜谱品类组件和右边的菜谱展示组件都可以访问recipeCache中的数据。当左边组件切换品类时,右边组件可以直接使用更新后的缓存数据进行渲染,而不需要重新获取数据,保证了数据在不同组件之间的同步和共享。
  3. 引用类型问题及深复制解决方案

    • 引用类型在响应式系统中的挑战

      • 在 JavaScript 中,对象和数组是引用数据类型。在 Vue 的响应式系统中,如果只是修改了引用数据类型内部的属性,而没有改变数据的引用地址,Vue 可能无法检测到数据的变化。
      • 例如,在recipeCache中存储的菜谱数据是一个对象。如果直接修改这个对象的某个属性,像这样:

        javascript

        this.$store.state.recipeCache[categoryIndex].recipeName = '新菜谱名称';
        

        Vue 可能不会触发组件的更新,因为数据的引用地址没有改变。
    • 深复制的原理与应用

      • 深复制是创建一个全新的对象,它的所有属性和子属性都是原始对象的副本。在mutation中进行深复制,可以确保每次更新数据时,数据的引用地址发生变化,从而触发 Vue 的响应式更新。
      • 假设我们有一个mutation用于更新recipeCache中的数据,可能会这样做:

        javascript

        mutations: {
          setRecipeData(state, { categoryIndex, data }) {
            // 使用深复制库(如lodash的cloneDeep)
            const newData = _.cloneDeep(data);
            state.recipeCache[categoryIndex] = newData;
          }
        }
        

        通过这种方式,每次更新数据时,都会将全新的数据副本赋值给recipeCache,使得 Vue 能够正确地检测到数据的变化并更新组件。
  4. 缓存清除与生命周期钩子的配合

    • 缓存清除的原因

      • 虽然缓存数据可以提高性能,但如果后台数据发生变化,而缓存没有更新,页面将显示旧的数据。因此,需要在适当的时候清除缓存,以便下次访问页面时能够重新获取最新的数据。
      • 例如,当用户退出菜谱页面或者在一定条件下(如后台数据更新通知),应该清除recipeCache中的数据。
    • 生命周期钩子的选择

      • destroyed 生命周期钩子:在组件正常销毁时,destroyed钩子会被触发。如果组件没有被Keep - alive包裹,这个钩子可以用来清除缓存。例如:

        javascript

        destroyed() {
          this.$store.commit('clearRecipeCache');
        }
        
      • deactivated 生命周期钩子:当组件被Keep - alive包裹时,组件在切换时不会被销毁,而是会触发deactivated钩子。在这种情况下,应该在deactivated钩子中清除缓存,以确保数据的及时更新。例如:

        javascript

        deactivated() {
          this.$store.commit('clearRecipeCache');
        }
        

        这里的clearRecipeCache是一个mutation,用于清除recipeCache中的数据,比如将recipeCache对象重置为空对象等操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2317370.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vllm-openai多服务器集群部署AI模型

服务器配置是两台ubantu系统电脑,每台电脑安装两张4090-48G显存的显卡,共计192G显存。 服务器1 服务器2 准备工作: 1.两台电脑都已经安装了docker 2.两台电脑都已经安装了nvidia驱动 参考vllm官方资料 https://docs.vllm.ai/en/latest/serving/distributed_serving.html…

在Spring Boot项目中接入DeepSeek深度求索,感觉笨笨的呢

文章目录 引言1. 什么是DeepSeek?2. 准备工作2.1 注册DeepSeek账号 3.实战演示3.1 application增加DS配置3.2 编写service3.3 编写controller3.4 编写前端界面chat.html3.5 测试 总结 引言 在当今快速发展的数据驱动时代,企业越来越重视数据的价值。为了…

STM32---FreeRTOS事件标志组

一、简介 事件标志位:用一个位,来表示事件是否发生 事件标志组:一组事件标志位的集合,可以简单的理解时间标志组,就是一个整体。 事件标志租的特点: 它的每一个位表示一个时间(高8位不算&…

Word 小黑第40套

对应大猫43 主题 -浏览主题 -选择W样式标准文件就行 1级段落和2级段落(用项目符号不影响原本段落文字符号 颜色修改为自动) 整段变红的 不是把光标定位到红色字体那里 要选择几个红色字体 再创建样式 插入的空白页一定要是下一页,不能插空白…

【Linux我做主】浅谈Shell及其原理

浅谈Linux中的Shell及其原理 Linux中Shell的运行原理github地址前言一、Linux内核与Shell的关系1.1 操作系统核心1.2 用户与内核的隔离 二、Shell的演进与核心机制2.1 发展历程2.2 核心功能解析2.3 shell的工作流程1. 用户输入命令2. 解析器拆分指令3. 扩展器处理动态内容变量替…

数据结构篇——二叉树的存储与遍历

一、引入 书接上文,文于此续。上文我们学到了树的存储结构,那么今天,我们来学习下几种特殊的二叉树以及关于它的各种遍历,让我们一起加油吧。 二、特殊的二叉树 二叉树的特殊形式这里介绍3种,其中需要着重记忆的有…

分而治之:用于 RGB-T 显著目标检测的 Confluent Triple-Flow 网络(问题)

摘要 问题一:RGB-thermal显著对象检测这是什么? RGB图像是可见光的三通道图像,而thermal是热红外图像,通常为单通道,记录物体的热辐射信息。结合RGB和thermal两种模态的数据,可以利用两者的互补信息&…

求职招聘网站源码,找工作招工系统,支持H5和各种小程序

招聘找活招工平台系统源码 招聘求职找工作软件 发布信息积分充值招聘系统,里面带纤细教程 功能介绍: 招工小程序主要针对工地招工工人找工作,工地可以发布招工信息,工人可以发布找活信息,招工信息可以置顶,置顶需要积分,积分可以通过签到、分享邀请好友、充值获取,后…

企业微信群聊机器人开发

拿到机器人hook 机器人开发文档 https://developer.work.weixin.qq.com/document/path/91770

基于Python的tkinter开发的一个工具,解析图片文件名并将数据自动化导出为Excel文件

文章目录 一、开发背景与业务价值二、系统架构设计1. 分层架构图解2. 核心类结构3. 文件解析流程 三、关键技术实现详解1. 高性能文件名解析引擎2. 可视化数据展示3. 智能Excel导出模块 四、完整代码五、行业应用展望 一、开发背景与业务价值 在零售行业会员管理场景中&#x…

Flutter_学习记录_状态管理之GetX

1. 状态管理、Flutter Getx介绍 1.1 状态管理 通俗的讲:当我们想在多个页面(组件/Widget)之间共享状态(数据),或者一个页面(组件/Widget)中的多个子组件之间共享状态(数…

【网络】数据流(Data Workflow)Routes(路由)、Controllers(控制器)、Models(模型) 和 Middleware(中间件)

在图片中,数据流(Data Workflow)描述了应用程序中数据的流动过程,涉及 Routes(路由)、Controllers(控制器)、Models(模型) 和 Middleware(中间件&…

Git下载安装(保姆教程)

目录 1、Git下载 2、Git安装(windows版) (1)启动安装程序 (2)阅读许可协议 (3)选择安装路径 (4)选择组件 (5)选择开始菜单文件夹…

Blender-MCP服务源码2-依赖分析

Blender-MCP服务源码2-依赖分析 有个大佬做了一个Blender-MCP源码,第一次提交代码是【2025年3月7号】今天是【2025年月15日】也就是刚过去一周的时间,所以想从0开始学习这个代码,了解一下大佬们的开发思路 1-核心知识点 from mcp.server.fas…

LabVIEW压比调节器动态试验台

本案介绍了一种基于LabVIEW的压比调节器动态试验台的设计,通过实用的LabVIEW图形化编程语言,优化了数据采集与处理的整个流程。案例通过实际应用展示了设计的专业性与高效性,以及如何通过系统化的方法实现精确的动态测试和结果分析。 ​ 项目…

2025-03-17 Unity 网络基础1——网络基本概念

文章目录 1 网络1.1 局域网1.2 以太网1.3 城域网1.4 广域网1.5 互联网(因特网)1.6 万维网1.7 小结 2 IP 地址2.1 IP 地址2.2 端口号2.3 Mac 地址2.4 小结 3 客户端与服务端3.1 客户端3.2 服务端3.3 网络游戏中的客户端与服务端 1 网络 ​ 在没有网络之前…

springboot441-基于SpringBoot的校园自助交易系统(源码+数据库+纯前后端分离+部署讲解等)

💕💕作者: 爱笑学姐 💕💕个人简介:十年Java,Python美女程序员一枚,精通计算机专业前后端各类框架。 💕💕各类成品Java毕设 。javaweb,ssm&#xf…

浅谈数据分析及数据思维

目录 一、数据分析及数据分析思维?1.1 数据分析的本质1.2 数据分析思维的本质1.2.1 拥有数据思维的具体表现1.2.2 如何培养自己的数据思维1.2.2.1 书籍1.2.2.2 借助工具1.2.2.3 刻意练习 二、数据分析的价值及必备能力?2.1 数据分析的价值2.1.1 现状分析…

自定义uniapp组件,以picker组件为例

编写目的 本文说明基于vue3定义uniapp组件的关键点: 1、一般定义在components文件夹创建组件,组件与页面已经没有明确的语法格式区别,所以可以与页面的语法保持一致 ; 2、组件定义后使用该组件的页面不需要引用组件即可使用&am…

【操作系统安全】任务4:Windows 系统网络安全实践里常用 DOS 命令

目录 一、引言 二、网络信息收集类命令 2.1 ipconfig 命令 2.1.1 功能概述 2.1.2 实例与代码 2.2 ping 命令 2.2.1 功能概述 2.2.2 实例与代码 2.3 tracert 命令 2.3.1 功能概述 2.3.2 实例与代码 三、网络连接与端口管理类命令 3.1 netstat 命令 3.1.1 功能概述…