从此告别表单数据丢失!vue教你缓存当前页面信息(keep-alive)

前言

在我们日常的开发工作中,经常会遇到这样的情况:用户填写了一个表单,但是在跳转到其他页面后,再次回到该页面时,之前填写的内容消失了。这不仅让用户感到不便,也让开发人员头疼不已。那么,有没有什么好的解决方案呢?答案是肯定的!本篇文章将介绍如何利用 vue 技术实现表单内容的缓存,让用户填写表单变得更加顺畅、愉悦。

未优化前

在这里插入图片描述

概念

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 让我们一起来看看优化后的效果

在这里插入图片描述


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水星记_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值