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

vue跳转页面后缓存当前表单内容(keep-alive)

前言

不知道大家日常有没有遇到这种情况,填写了好一会的表单,跳转了个页面,再次返回的时候,表单已经被清空了,用户体验非常友好,那有没有什么办法可以解决这个问题呢?其实通过 vuekeep-alive 语法就能解决这个问题。

未优化前

在这里插入图片描述

概念

1. 什么是 keep-alive?

在使用 keep-alive 之前我们首先要知道什么是 keep-alivekeep-alivevue 的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。它自身不会渲染成一个 DOM 元素,也不会出现在父组件链中。


2. keep-alive 的作用?

组件切换的过程中将状态保留在内存中,防止重复渲染 DOM,减少加载时间及性能消耗,提高用户体验性。


3. keep-alive 的原理?

created 生命周期函数调用时将需要缓存的 VNode 节点保存在 this.cache 中,在页面渲染时,如果 VNodename 符合缓存条件(可以用 include 以及 exclude 控制),则会从 this.cache 中取出之前缓存的 VNode 实例进行渲染。


4. keep-alive 有哪些参数?

keep-alive 可以接收 3 个属性做为参数进行匹配对应的组件进行缓存:

参数描述
include定义缓存白名单。可以是字符串,数组,以及正则表达式,只有匹配的组件会被缓存
exclude定义缓存黑名单。可以是字符串,数组,以及正则表达式,任何匹配的组件都不会被缓存
max缓存组件上限。类型为字符串或者数字,可以控制缓存组件的个数

5. keep-alive 的生命周期函数?

只有组件被 keep-alive 包裹时,这两个生命周期函数才会被调用,如果作为正常组件使用,是不会被调用的,以及在 2.1.0 版本之后,使用 exclude 排除之后,就算被包裹在 keep-alive 中,这两个钩子函数依然不会被调用。另外,在服务端渲染时,此钩子函数也不会被调用。

钩子函数描述
activated在 keep-alive 组件激活时调用,该钩子函数在服务器端渲染期间不被调用。
deactivated在 keep-alive 组件停用时调用,该钩子在服务器端渲染期间不被调用。

看到这里,相信你对 keep-alive 已经有了初步的认识,那具体在项目中要怎么使用呢?下面进入实战操作。


使用

1. 在 App.vue 文件中添加 keep-alive 标签

App.vue

<template>
  <div id="app">
    <keep-alive>
      <router-view v-if="$route.meta.keepAlive" />
    </keep-alive>
    <router-view v-if="!$route.meta.keepAlive" />
  </div>
</template>

2. 在路由文件中添加 meta (未跳转之前的页面)

router/index.js

{
	path: '/as',
	name: 'as',
	component: () => import('@/views/as'),
	meta: {
		keepAlive: true
	}
},

3. 在跳转的新页面中添加 beforeRouteLeave

views/ass.vue

methods: {
  beforeRouteLeave(to, from, next) {
    to.meta.keepAlive = true;
    next(0);
  },
},

3.1 生命周期的执行顺序

1.不使用 keep-alive 的情况:

beforeRouteEnter --> created --> mounted --> destroyed

2.使用 keep-alive 的情况:

beforeRouteEnter --> created --> mounted --> activated --> deactivated

3.使用 keep-alive,并且再次进入了缓存页面的情况:

beforeRouteEnter --> activated --> deactivated

3.2 让我们一起来看看优化后的效果

在这里插入图片描述


相关文章:

  • 设计模式之外观模式
  • 计网重点知识总结复习
  • 解除Excel限制编辑的两种方法
  • MOOC武大SAS——第一章作业
  • 进行ISO27001认证需要准备的几个阶段
  • 3322动态域名怎么解析?
  • 线上展厅怎样设计完美
  • Android修行手册 - GridView实践回忆
  • Spring DI和AOP简介
  • 以太坊改造完成,矿工要失业了?
  • dubbo拓展点机制(和对JDK SPI机制的优化)
  • HTML常用标签积累
  • 【一起学SQLite】--SQLite中一些与众不同的特性?(2-1)
  • A+文档丨Azure MySQL 数据库高可用性解析
  • 【Python基础】Numpy:切片和索引操作
  • Iterator 和 for...of 循环
  • Java反射-动态类加载和重新加载
  • miaov-React 最佳入门
  • Objective-C 中关联引用的概念
  • sessionStorage和localStorage
  • Shadow DOM 内部构造及如何构建独立组件
  • spring boot下thymeleaf全局静态变量配置
  • Travix是如何部署应用程序到Kubernetes上的
  • Zsh 开发指南(第十四篇 文件读写)
  • 如何设计一个微型分布式架构?
  • - 转 Ext2.0 form使用实例
  • ​LeetCode解法汇总518. 零钱兑换 II
  • ​渐进式Web应用PWA的未来
  • # centos7下FFmpeg环境部署记录
  • #NOIP 2014# day.1 T2 联合权值
  • #stm32整理(一)flash读写
  • (C++20) consteval立即函数
  • (LeetCode C++)盛最多水的容器
  • (TipsTricks)用客户端模板精简JavaScript代码
  • (附源码)spring boot车辆管理系统 毕业设计 031034
  • (力扣)循环队列的实现与详解(C语言)
  • (十五)devops持续集成开发——jenkins流水线构建策略配置及触发器的使用
  • (一)基于IDEA的JAVA基础12
  • (一一四)第九章编程练习
  • .Net CF下精确的计时器
  • .net core 6 redis操作类
  • .net core Swagger 过滤部分Api
  • .NET Core 通过 Ef Core 操作 Mysql
  • .NET Reactor简单使用教程
  • .NET 表达式计算:Expression Evaluator
  • .NET设计模式(11):组合模式(Composite Pattern)
  • .set 数据导入matlab,设置变量导入选项 - MATLAB setvaropts - MathWorks 中国
  • /3GB和/USERVA开关
  • /usr/bin/env: node: No such file or directory
  • @RequestParam @RequestBody @PathVariable 等参数绑定注解详解
  • @Responsebody与@RequestBody
  • @Tag和@Operation标签失效问题。SpringDoc 2.2.0(OpenApi 3)和Spring Boot 3.1.1集成
  • [2019.2.28]BZOJ4033 [HAOI2015]树上染色
  • [28期] lamp兄弟连28期学员手册,请大家务必看一下
  • [EFI]Dell Inspiron 15 5567 电脑 Hackintosh 黑苹果efi引导文件