keep-alive标签的使用注意事项及使用场景

news2024/11/5 15:59:26

keep-alive标签为<keep-alive></keep-alive>,是Vue内置的一个组件,可以使被包含的组件保留状态或避免重新污染。

keep-alive应用在<route-view>上的demo。

keep-alive文件


<template>
   <div>
        <div>
            <router-link to="/keep/date">date</router-link>
            <router-link to="/keep/user">user</router-link>
        </div>
        <div style="margin-top: 15px">
            <router-view v-slot="{ Component }">
                <keep-alive :include="/Include/">
                    <component :is="Component"></component>
                </keep-alive>
            </router-view> 
        </div>
   </div>
</template>


import { defineComponent } from "vue";

export default defineComponent({
    name: 'keepalive',
})

user文件

<template>
    <div>
        user文件
        <input type="text">
    </div>
</template>
import { defineComponent } from "vue";

export default defineComponent({
    name: 'keepUserInclude'
})

date文件

<template>
    <div>
        date文件
        <input type="date">
    </div>
</template>
import { defineComponent } from "vue";

export default defineComponent({
    name: 'keepDate'
})

route文件配置

import { createRouter, createWebHistory } from 'vue-router'

const router = createRouter({
  history: createWebHistory('./'),
  routes: [
    {
      path: '/keep',
      name: 'KeepAlive',
      redirect: '/keep/user',
      component: () => import(/* webpackChunkName: 'keep-alive' */ '@/views/keep-alive/index.vue'),
      children: [
        {
          path: 'user',
          name: 'KeepUser',
          component: () => import(/* webpackChunkName: 'keep-user' */ '@/views/keep-alive/components/user.vue')
        },
        {
          path: 'date',
          name: 'KeepDate',
          component: () => import(/* webpackChunkName: 'keep-page' */ '@/views/keep-alive/components/date.vue')
        },
      ]

    },
    
  ]
})

export default router

上面的代码中,只有user组件的内容会被缓存。include/exclude可以设置单个字符串或者正则表达式,也可以是一个由字符串或者正则表达式组成的数组,匹配内容是组件名称。该段代码使用include仅缓存包含’/Include/'的字符串。exclude表示不需要缓存的文件。

**组件名称是组件的name属性。

export default defineComponent({
    name: 'keepUserInclude'
})

keep-alive保留user组件上的内容

缓存实例的生命周期

两个生命周期钩子函数:

import { defineComponent, onActivated, onDeactivated } from 'vue'

export default defineComponent({
  
  setup() {
    onActivated() {
      // 调用时机为首次挂载及每次从缓存中被重新插入时
    }
    
    
    onDeactivated() {
      // 从DOM上移除、进入缓存以及在组件卸载时调用
    }
  }
})

使用<keep-alive>时应当谨慎,不当的使用可能会导致内存占用过高,特别是当缓存了很多大组件或者不再需要的组件时。可以通过max参数来限制可被缓存的最大组件实例数。

<router-view v-slot="{ Component }">
  <keep-alive :include="/Include/" :max="10">
    <component :is="Component"></component>
  </keep-alive>
</router-view> 

使用场景

1.提升用户体验:

  • 路由切换:当用户在多个视图间频繁切换时,使用<keep-alive>可以保持组件状态,避免重新加载,提升应用响应速度和用户体验。
  • 表单填写:在需要参考其他页面进行表单填写时,切换回来后不需要重新填写表单。

2.避免重复请求:

  • 数据获取:对于需要从服务器获取数据的组件,使用<keep-alive>可以避免在组件切换时重复发送请求。
  • 优化性能:如果组件的重渲染开销很大,使用<keep-alive>可以减少不必要的渲染,从而提高性能。

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

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

相关文章

Oracle视频基础1.4.3练习

15个视频 1.4.3 できない dbca删除数据库 id ls cd cd dbs ls ls -l dbca# delete a database 勾选 # chris 勾选手动删除数据库 ls ls -l ls -l cd /u01/oradata ls cd /u01/admin/ ls cd chris/ ls clear 初始化参数文件&#xff0c;admin&#xff0c;数据文件#新版本了…

一个由Deno和React驱动的静态网站生成器

大家好&#xff0c;今天给大家分享一个由 Deno React 驱动的静态网站生成器Pagic。 项目介绍 Pagic 是一个由 Deno React 驱动的静态网站生成器。它配置简单&#xff0c;支持将 md/tsx 文件渲染成静态页面&#xff0c;而且还有大量的官方或第三方主题和插件可供扩展。 核心…

1分钟解决Excel打开CSV文件出现乱码问题

一、编码问题 1、不同编码格式 CSV 文件有多种编码格式&#xff0c;如 UTF - 8、UTF - 16、ANSI 等。如果 CSV 文件是 UTF - 8 编码&#xff0c;而 Excel 默认使用的是 ANSI 编码打开&#xff0c;就可能出现乱码。例如&#xff0c;许多从网络应用程序或非 Windows 系统生成的 …

发布天工AI高级搜索功能,昆仑万维做最懂科研学术的AI搜索

今天&#xff0c;昆仑万维天工AI正式发布最新版本的AI高级搜索功能。 一年时光&#xff0c;栉风沐雨。昆仑万维致力于通过领先的AI技术&#xff0c;为全球用户提供创新的智能搜索和信息处理解决方案。无论是金融、科技领域的专业搜索还是文档分析&#xff0c;「天工AI高级搜索…

mac找到主目录下的文件夹

访达-&#xff08;上方状态栏显示&#xff09;-然后在

安装fpm,解决*.deb=> *.rpm

要从生成 .deb 包转换为 .rpm 包&#xff0c;可以按照以下步骤修改打包脚本 1. 使用 fpm 工具 fpm 是一个强大的跨平台打包工具&#xff0c;可以将 .deb 包重新打包成 .rpm&#xff0c;也可以直接从源文件打包成 .rpm。 安装 fpm sudo apt-get install ruby-dev sudo gem in…

分布式光伏管理办法

随着分布式光伏项目的不断增加&#xff0c;传统的管理方式已经难以满足高效、精准的管理需求。光伏业务管理系统作为一种集信息化、智能化于一体的管理工具&#xff0c;正在逐步成为分布式光伏项目管理的重要支撑。 光伏业务管理系统通过数字化手段实现对光伏业务全流程的精细化…

数据结构:LRUCache

什么是LRUCache 首先我们来看看什么是cache 缓存&#xff08;Cache&#xff09;通常用于两个速度不同的介质之间&#xff0c;以提高数据访问的速度和效率。这里有几个典型的应用场景&#xff1a; 处理器和内存之间&#xff1a; 处理器&#xff08;CPU&#xff09;的运算速度远…

智能提醒助理系列-springboot项目彩虹日志+TraceID

本系列文章记录“智能提醒助理”产品建设历程&#xff0c;记录实践经验、巩固知识点、锻炼总结能力。 本篇介绍如何让springboot启动日志“彩打” 提升日志识别度&#xff0c;同时增加TraceID&#xff0c;便于同一请求&#xff0c;全链路的追踪。 一、需求出发点 提升日志识别度…

窨井监测遥测终端RTU IP68防水强信号穿透力

在窨井的潮湿 黑暗和腐蚀性环境中 常规物联网设备往往难以生存 如何突破层层环境挑战 轻松应对极端条件 确保信号 24h不掉线&#xff0c;不延迟 不仅是对技术的突破 更是对恶劣环境的征服 ↓↓↓ 坚守 ——严苛环境下的工业设备 计讯物联工业级设备&#xff0c;专为恶劣环境设计…

150道MySQL高频面试题,学完吊打面试官--如何实现索引机制

前言 本专栏为150道MySQL大厂高频面试题讲解分析&#xff0c;这些面试题都是通过MySQL8.0官方文档和阿里巴巴官方手册还有一些大厂面试官提供的资料。 MySQL应用广泛&#xff0c;在多个开发语言中都处于重要地位&#xff0c;所以最好都要掌握MySQL的精华面试题&#xff0c;这也…

基于Matlab 模拟停车位管理系统【源码 GUI】

系统对进入停车位的车辆进行车牌识别&#xff0c;将识别出来的车牌号显示出来&#xff1b;然后对车主进行人脸识别&#xff0c;框出车主照片的人脸部分作为车主信息的标记&#xff0c;记录在系统库中。车辆在库期间&#xff0c;系统使用者可以随意查看车辆与车主信息的获取过程…

微信小程序 https://pcapi-xiaotuxian-front-devtest.itheima.net 不在以下 request 合法域名

微信小程序在调用接口的时候出现以上报错&#xff0c;接口没有问题&#xff0c;是因为小程序自动校验了合法域名 打开本地设置&#xff1a; 勾选不校验合法域名&#xff0c;即可 效果如下&#xff1a;

数据治理,数据提取,大数据中心建设,大数据治理总体解决方案书(word,ppt原件)

1. 数据管理的现状 2. 数据治理的概述 1.1数据治理概念 2.2数据治理目标 3. 数据治理体系 4. 数据治理核心领域 1.1 数据模型 1.2 数据生命周期 &#xff08;1&#xff09;数据生成及传输 &#xff08;2&#xff09;数据存储 &#xff08;3&#xff09;数据处理和应用…

电机控制储备知识 二:电磁学理论知识

一&#xff1a;磁场的发现过程和和一些实验现象 古代发现&#xff1a;公元前七世纪&#xff0c;中国和古希腊的学者就已经发现了磁石。 吉尔伯特的研究&#xff1a;1600年&#xff0c;英国女王御臣威廉吉尔伯特&#xff08;William Gilbert&#xff09;发表了《地磁论》&#…

Java:数组的定义和使用(万字解析)

目录 1. 数组的概念 2. 数组的基础知识 2.1 数组的创建 \1. 基础创建格式&#xff1a; \2. 类似C语言的创建格式&#xff1a; 【错误的创建(初始化)格式】 2.2 数组的数据类型 2.3 数组的初始化 —— 两种方式 \1.动态初始化&#xff1a;(完全默认初始化) \2. 静态初…

ProLightsfx新的出发–从CSDN到WordPress

原文链接&#xff1a;ProLightsfx新的出发--从CSDN到WordPress_ProLightsfx的技术分享 &#xff08;https://www.prolightsfxjh.com/article/article-new-start/&#xff09; 大概有差不多2年时间没有在csdn发布文章了。可能主要是最近几年工作有些疲惫、精神有些懈怠&#xff…

【react】Redux基础用法

1. Redux基础用法 Redux 是一个用于 JavaScript 应用的状态管理库&#xff0c;它不依赖于任何 UI库&#xff0c;但常用于与 React 框架配合使用。它提供了一种集中式的状态管理方式&#xff0c;将应用的所有状态保存在一个单一的全局 Store&#xff08;存储&#xff09;中&…

VMware虚拟机Debian扩展磁盘

一、 版本 VMware&#xff1a;Workstation 17 Pro虚拟机&#xff1a;Debian11 二、 VMware虚拟机扩展 虚拟机关机状态快照或者备份&#xff1a;以免扩容失败导致文件丢失虚拟机——设置——硬盘——磁盘使用工具——扩展——扩展磁盘容量——设置为想要的大小 三、 虚拟机…

软件设计师-上午题-16 算法(4-5分)

算法题号一般为62-65题(数据结构与算法题号为57-65&#xff0c;共9分)&#xff0c;分值一般为4-5分。 目录 1 回溯法 1.1 N皇后问题 1.2 非递归求解N皇后问题 1.3 递归求解N皇后问题 1.4 真题 2 分治法 2.1 最大字段和问题 2.2 真题 3 动态规划 3.1 0-1背包问题 3.…