vue中缓存组件keep alive的介绍及使用方法

目录
  • 介绍
  • 使用
    • 缓存所有的组件
    • 缓存某个组件
    • keep-alive的使用示例
  • include和exclude属性的使用
    • include的使用
    • exclude的使用
  • 生命周期

介绍

keep-alive是vue的内置组件,可以用来缓存组件。当它包裹动态组件时,会缓存不活动的组件实例,不会销毁它们;将不活动的组件的状态保留在内存中,可以防止重复渲染DOM,减少加载事件和性能消耗。

注意:keep-alive是一个抽象组件,自身不会渲染成一个DOM元素,也不会出现在父组件链中。

原理:

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

使用

缓存所有的组件

在APP.js中缓存所有组件

<template>
  <div id="app">
    <keep-alive>
      <NativeBtn>
      <router-view />
    </keep-alive>
  </div>
</template>

缓存某个组件

缓存某个组件就直接在该组件的外层嵌套一层<keep-alive>

<template>
  <div id="app">
    <!-- 只缓存NativeBtn组件 -->
    <keep-alive>
      <NativeBtn />
    </keep-alive>
    <router-view />
  </div>
</template>

keep-alive的使用示例

先来看看不加keep alive的情况

代码:

keepAliveDemo的代码

<template>
  <div>
    <button @click="changeComp">切换</button>
    <component :is="showComp" />
  </div>
</template>
<script>
import KeepAlivePageC from "./KeepAlivePageC.vue";
import KeepAlivePageB from "./KeepAlivePageB.vue";
export default {
  name: "keepAliveDemo",
  components: { KeepAlivePageC, KeepAlivePageB },
  data() {
    return {
      compType: "1",
    };
  },
  computed: {
    showComp() {
      if (this.compType === "1") {
        return KeepAlivePageC;
      } else {
        return KeepAlivePageB;
      }
    },
  },
  methods: {
    changeComp() {
      console.log("==== 点击切换按钮");
      this.compType = this.compType === "1" ? "2" : "1";
    },
  },
};
</script>

KeepAlivePageB的代码

<template>
  <div>KeepAlivePageB</div>
</template>
<script>
export default {
  name: "KeepAlivePageB",
  beforeCreate() {
    console.log(" KeepAlivePageB beforeCreate 方法执行了");
  },
  created() {
    console.log(" KeepAlivePageB created 方法执行了");
  },
  beforeMount() {
    console.log(" KeepAlivePageB beforeMount 方法执行了");
  },
  mounted() {
    console.log(" KeepAlivePageB mounted 方法执行了");
  },
  beforeUpdate() {
    console.log(" KeepAlivePageB beforeUpdate 方法执行了");
  },
  updated() {
    console.log(" KeepAlivePageB updated 方法执行了");
  },
  beforeDestroy() {
    console.log(" KeepAlivePageB beforeDestroy 方法执行了");
  },
  destroyed() {
    console.log(" KeepAlivePageB destroyed 方法执行了");
  },
};
</script>

KeepAlivePageC的代码

<template>
  <div>KeepAlivePageC</div>
</template>
<script>
export default {
  name: "KeepAlivePageC",
  beforeCreate() {
    console.log(" KeepAlivePageC beforeCreate 方法执行了");
  },
  created() {
    console.log(" KeepAlivePageC created 方法执行了");
  },
  beforeMount() {
    console.log(" KeepAlivePageC beforeMount 方法执行了");
  },
  mounted() {
    console.log(" KeepAlivePageC mounted 方法执行了");
  },
  beforeUpdate() {
    console.log(" KeepAlivePageC beforeUpdate 方法执行了");
  },
  updated() {
    console.log(" KeepAlivePageC updated 方法执行了");
  },
  beforeDestroy() {
    console.log(" KeepAlivePageC beforeDestroy 方法执行了");
  },
  destroyed() {
    console.log(" KeepAlivePageC destroyed 方法执行了");
  },
};
</script>

不使用keep alive时,切换按钮会有组件的创建和销毁

再来看下使用keep alive的情况。修改keepAliveDemo布局代码

<template>
  <div>
    <button @click="changeComp">切换</button>
    <keep-alive>
      <component :is="showComp" />
    </keep-alive>
  </div>
</template>

发现开始会有组件的创建,但是没有组件的销毁,当两个组件都创建了实例之后,再点击切换按钮,组件既不创建也不销毁,说明使用了缓存的组件实例。

include和exclude属性的使用

include:字符串或者正则表达式。只有匹配的组件会被缓存;

exclude:字符串或者正则表达式。任何匹配的组件都不会被缓存。

include的使用

只有匹配上的组件才会被缓存,没匹配上的组件不会被缓存。

修改keepAliveDemo布局代码如下

<template>
  <div>
    <button @click="changeComp">切换</button>
    <keep-alive include="KeepAlivePageC">
      <component :is="showComp" />
    </keep-alive>
  </div>
</template>

可以看到KeepAlivePageC只创建了一次,而KeepAlivePageB一直在创建和销毁

exclude的使用

匹配上的组件不会被被缓存,没匹配上的组件会被缓存。

修改keepAliveDemo布局代码如下

<template>
  <div>
    <button @click="changeComp">切换</button>
    <keep-alive exclude="KeepAlivePageC">
      <component :is="showComp" />
    </keep-alive>
  </div>
</template>

可以看到KeepAlivePageB只创建了一次,而KeepAlivePageC一直在创建和销毁

生命周期

和keep-alive相关的生命钩子是activated和deactivated

activated:被 keep-alive 缓存的组件激活时调用

deactivated:被 keep-alive 缓存的组件失活时调用

在KeepAlivePageB和KeepAlivePageC中添加activated和deactivated钩子,依然使用上面的exclude的例子

可以看到当KeepAlivePageB活动使会执行activated钩子,失活时会调用deactivated钩子

到此这篇关于vue中缓存组件keep alive的介绍及使用方法的文章就介绍到这了,更多相关vue keep alive内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 详解Vue中的keep-alive

    目录 1. 简介 2. 使用 2.1 参数 2.2 生命周期函数 2.3 应用场景 总结 1. 简介 keep-alive 是 Vue 的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们.和 transition 相似,keep-alive 是一个抽象组件:它自身不会渲染成一个 DOM 元素,也不会出现在父组件链中. 作用: 在组件切换过程中将状态保留在内存中,防止重复渲染DOM,减少加载时间及性能消耗,提高用户体验性. 原理: 在 created 函数调用时将需要缓存的 V

  • vue关于点击详情页面keep-alive的缓存问题

    目录 点击详情页面keep-alive的缓存问题 vue中路由表单缓存(keep-alive) 页面效果 父组件代码 被缓存组件代码 点击详情页面keep-alive的缓存问题 今天有个列表 点击以后 进入详情 然后在返回,再点击其他的列表数据,详情页面请求的还是上一次请求的id 除非刷新才会请求现在的. 这样子对用户体验感是非常不好滴,查了半天资料 发现了activated这个api 解决有些不需要被缓存的组件页面 设置 activated 即可以再次进行事件的响应 vue中路由表单缓存(ke

  • vue自定义keepalive组件的问题解析

    目录 vue自定义keepalive组件 为什么会出现这种情况呢 如何解决这个问题呢 问题知道了怎么解决呢 思路有了撸代码 如何使用 主题说完了,整点其他的 vue自定义keepalive组件 前一阵来了一个新的需求,要在vue项目中实现一个多开tab页面的功能,本来心想,这不简单嘛就是一个增加按钮重定向吗?(当然如果这么简单我就不写这个文章了).很快写完,提交测试.测试大哥很快就提交了一个问题:"你两个tab页访问同一个链接,怎么还是个联动的呢?".我擦,这指定是缓存的问题. 为什么

  • vue中keep-alive组件实现多级嵌套路由的缓存

    目录 现状(问题): 探索方案: 实现方式 现状(问题): keep-alive 组件对第三级及以上级的路由页面缓存失效 探索方案: 方案1.直接将路由扁平化配置,都放在一级或二级路由中方案2.再一层缓存组件用来过渡,并将其name配置到include中 实现方式 方案1不需要例子,按规则配置路由就行重点介绍方案2因为我用了vue-element-admin做了架构,并且项目中我将菜单和路由全部通过服务端返回做了统一配置,所以我只能用方案2来实现. 直接看原有代码(问题代码) // src/la

  • Vue keep-alive的实现原理分析

    目录 keep-alive的实现原理 这里以vue3为例 大致流程如下 keep-alive生命周期 keep-alive的使用总结 1.App.vue中使用keep-alive 2.App.vue中配合router进行使用 keep-alive的实现原理 使用vue的时候,想必大家都是用过keep-alive,其作用就是缓存页面以及其状态.使用了这么久vue只知道如何使用但不明白其中原理,昨天翻看实现代码,这里做个笔记. 这里以vue3为例 整个组件的源码为: const KeepAliveI

  • Vue动态组件和keep-alive组件实例详解

    目录 动态组件 格式 注意点 使用效果 目录结构 操作 效果 小结 keep-alive组件 使用背景 解决方法 使用keep-alive组件 小结 keep-alive组件-指定缓存 语法 注意: 总结 动态组件 多个组件使用同一个挂载点,并可以动态切换,这就是动态组件. 格式 <component :is="comName"></component> 注意点 is只能是动态属性,:is="组件注册后的标签名字符串或data变量" 不能直接

  • 详解Vue适时清理keepalive缓存方案

    目录 需求 思考 尝试 1. 手动操作 keep-alive 组件的 cache 数组 2. exclude 大法好 Demo 需求 单页面应用中,用户进入表单填写页面,需要初始化表单内容,填写过程中可能涉及到地图选点或者列表选择等操作,需要到新的页面选择并回调显示. 此时我们需要缓存表单填写页面实例,当退出表单填写或提交完表单内容之后,需要销毁当前表单实例,下次进入重新进行初始化 思考 说到 Vue 缓存,我们肯定首先选择官方提供的缓存方案 keep-alive 内置组件来实现. keep-a

  • vue之keepAlive使用案例详解

    在开发中经常有从列表跳到详情页,然后返回详情页的时候需要缓存列表页的状态(比如滚动位置信息),这个时候就需要保存状态,要缓存状态:vue里提供了keep-alive组件用来缓存状态. 可以用以下几种方案解决问题: 一.利用meta标签 1.首先在路由中的meta标签中记录keepAlive的属性为true path: '/classify', name: 'classify', component: () => import('@/views/classify/classify.vue'), m

  • vue中缓存组件keep alive的介绍及使用方法

    目录 介绍 使用 缓存所有的组件 缓存某个组件 keep-alive的使用示例 include和exclude属性的使用 include的使用 exclude的使用 生命周期 介绍 keep-alive是vue的内置组件,可以用来缓存组件.当它包裹动态组件时,会缓存不活动的组件实例,不会销毁它们:将不活动的组件的状态保留在内存中,可以防止重复渲染DOM,减少加载事件和性能消耗. 注意:keep-alive是一个抽象组件,自身不会渲染成一个DOM元素,也不会出现在父组件链中. 原理: 在 crea

  • vue中拆分组件的实战案例

    目录 一.组件化诞生的历史 二.为什么业务组件越开发越难维护 人的问题 技术问题 2.1 项目现状 2.2 理想目标 三.举一个实际的例子 3.1 需求背景 3.2 开发之前: 前端设计文档 数据流向图 目录结构 逻辑控制 拆分的原则 3.3 受控组件和非受控组件 3.4 开发进行: 逻辑变量和UI变量 四.持续的优化 五.可能的问题 五.实践是学习前端的捷径 总结 组件化是一种思维的表现,这种技能映射到人的本质是,一个人是否有能力把一个复杂的问题拆解.简单化的能力. 一.组件化诞生的历史 我们

  • Vue中UI组件库之Vuex与虚拟服务器初识

    一.日历组件 new Date()的月份是从0开始的. 下面表达式是:2018年6月1日 new Date(2018, 5, 1); 下面表达式是:2018年5月1日 new Date(2018, 4, 1); 或 new Date(2018, 5-1, 1); 下面表达式是:2018年5月31日(得到上个月的最后一天) new Date(2018, 5 , 0); 日的参数可以是0,也可以是负数,表示上个月底的那一天. 下面表达式是:2018年7月01日 new Date(2018, 5, 3

  • Vue中keep-alive组件的深入理解

    前言 最近在写Vue项目的时候,遇到了一个问题,我从A路由使用parmas方式传参跳转到B路由,然后从B路由跳转到C路由,再从C路由返回B路由的时候,发现从A路由传到B路由的参数已经不存在了. 正文 我们都知道,vue组件进行路由跳转时,会销毁当前组件.所以从其他路由返回当前路由时,当前路由会重新执行生命周期钩子函数.这就导致了上述问题,A路由传到B路由的参数没了. 当遇到这种问题的时候,我们会首先想到,我们能不能让B路由的数据保存下来呢?这就不得不提到Vue的一个组件了,它就是keep-ali

  • vue中keep-alive组件的用法示例

    问题描述(什么是keep-alive) keep-alive顾名思义,保持活跃.保持谁活跃呢? 首先我们知道,因为vue就是组件化编程,一个.vue文件就是一个组件.就像万事万物一样,都有从出生到消亡的生命周期过程,vue的组件也是一样,也有自己的生命周期,比如create创建组件.mounted往组件上挂数据.update更新组件上挂的数据,destroy把组件实例销毁. 所以使用keep-alive就是保持组件活跃,不会被destroy销毁掉,就一直还活着,组件没有被销毁掉的话,组件上挂载的

  • vue中keepAlive组件的作用和使用方法详解

    前言 在面试的时候,很多面试官再问vue的时候可能就会提一嘴,你知道keep-alive有什么作用吗? keep-alive是vue内置的一个组件,而这个组件的作用就是能够缓存不活动的组件,我们能够知道,一般情况下,组件进行切换的时候,默认会进行销毁,如果有需求,某个组件切换后不进行销毁,而是保存之前的状态,那么就可以利用keep-alive来实现 <keep-alive>是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM. <keep-alive> 包裹

  • Vue中父组件向子组件通信的方法

    Vue是一个轻量级的渐进式框架,对于它的一些特性和优点在此就不做赘述.下面通过本文给大家分享Vue中父组件向子组件通信的方法,具体内容详情如下所示: props 组件实例的作用域是孤立的.子组件的模板中是无法直接调用父组件的数据. 可以使用props将父组件的数据传给子组件.子组件在接受数据时要显示声明props 看下面的例子 <div id="app"> <panda here='China'></panda> </div> <s

  • vue中各组件之间传递数据的方法示例

    前言 本文主要给大家介绍了关于vue组件之间传递数据的相关资料,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍: 作用域 在vue中,组件实例的作用域是孤立的,父组件模板的内容在父组件作用域内编译:子组件模板的内容在子组件作用域内编译.这意味着不能 (也不应该) 在子组件的模板内直接引用父组件的数据. 下面几种方法可以实现组件之间数据的传递. 一.通过prop传递数据 1)在子组件中,使用prop属性,显示的表明,它所需要的数据. 2)在父组件中,需要引用子组件的地方,传入数据.

  • vue中component组件的props使用详解

    本文介绍了 vue中component组件的props使用详解,分享给大家,具体如下: props使用方法 Vue.component('my-component',{ props:['message'], template:'<div class="tem1">{{message}}</div>' }); <my-component message="hello"></my-component> 注意:props 的

随机推荐