详解如何优雅运用Vue中的KeepAlive组件

 更新时间:2023年09月18日 09:17:34   作者:牛哥说我不优雅  
在Vue中,KeepAlive组件是一种特殊的组件,用于缓存已经渲染过的组件实例,本文主要为大家详细介绍了KeepAlive组件的用法,需要的小伙伴可以参考下

一、引言

Vue.js是一款流行的前端框架,它提供了许多方便的特性来帮助我们构建交互式的用户界面。其中一个重要的特性是Keep-Alive组件,它可以在组件切换时保持组件的状态,从而提升用户体验。

二、什么是KeepAlive

在Vue中,KeepAlive组件是一种特殊的组件,用于缓存已经渲染过的组件实例。它可以将组件保存在内存中,以避免每次重新渲染组件时都执行组件的生命周期钩子函数和重新渲染DOM的开销。

官网原话: <KeepAlive>是一个内置组件,它的功能是在多个组件间动态切换时缓存被移除的组件实例。

三、KeepAlive的基本用法

KeepAlive组件是Vue的内置组件,通过将其包裹在需要缓存的组件外部,可以实现组件状态的保留。

<template>
  <KeepAlive>
    <component :is="currentComponent"></component>
  </KeepAlive>
</template>

上面的代码示例是通过Vue的<component>元素和特殊的is属性实现的,可以使用:is属性来指定要渲染的组件。:is属性的值可以是一个组件的选项对象,也可以是一个组件的名称。

<component>是一个动态组件,根据currentComponent的值来动态加载不同的子组件。

四、缓存和销毁

默认情况下,KeepAlive会缓存所有传递给它的组件实例,但你可以通过使用includeexclude属性来明确指定哪些组件需要缓存或排除。

<template>
  <KeepAlive :include="['ComponentA']" :exclude="['ComponentB']">
    <component :is="currentComponent"></component>
  </KeepAlive>
</template>

在上面的代码示例中,ComponentA会被缓存,而ComponentB不会。

通过:include属性,我们可以指定需要缓存的组件,这里使用了数组['ComponentA']来指定只缓存ComponentA组件的实例。

通过:exclude属性,我们可以指定不需要缓存的组件,这里使用了数组['ComponentB']来指定不缓存ComponentB组件的实例。

<!-- 以英文逗号分隔的字符串 -->
<KeepAlive include="a,b">
  <component :is="view" />
</KeepAlive>
<!-- 正则表达式 (需使用 `v-bind`) -->
<KeepAlive :include="/a|b/">
  <component :is="view" />
</KeepAlive>
<!-- 数组 (需使用 `v-bind`) -->
<KeepAlive :include="['a', 'b']">
  <component :is="view" />
</KeepAlive>

KeepAlive组件的include属性可以接收一个字符串、正则表达式或一个数组,用于指定哪些组件需要被缓存。

  • 字符串:可以是组件的名称,用于指定具体的组件需要被缓存。
  • 正则表达式:可以使用正则表达式来匹配组件的名称,所有匹配成功的组件都会被缓存。
  • 数组:可以包含多个组件名称,用于指定多个组件需要被缓存。

五、最大缓存实例数

我们可以通过传入max值来限制可被缓存的最大组件实例数。

<KeepAlive :max="10">
  <component :is="activeComponent" />
</KeepAlive>

在上述的代码示例中,如果组件实例数超过10个时(超出了指定的最大数量),就按LRU算法将最长时间没被访问的缓存实例销毁,来为新的实例腾出空间。

六、配合动态组件使用

KeepAlive特别适用于动态组件的场景,它可以保留动态组件的状态,让用户在不同组件之间切换时保持良好的交互体验。

<template>
  <KeepAlive>
    <component :is="currentComponent"></component>
  </KeepAlive>
</template>
<script>
export default {
  data() {
    return {
      currentComponent: 'ComponentA'
    };
  }
}
</script>

通过:is="currentComponent",我们动态地渲染不同的组件。

currentComponent是一个数据属性,初始值为'ComponentA',表示要渲染的组件是ComponentA。通过改变currentComponent的值,我们可以在运行时切换渲染不同的组件,从而实现动态组件的切换效果。

七、KeepAlive组件的生命周期

KeepAlive组件有自己的生命周期钩子函数,可以在需要时进行操作。一个持续存在的组件可以通过onActivated()和onDeactivated()注册相应的两个状态的生命周期钩子。

  • onActivated:当组件被激活时调用,对应Vue组件的onActivated钩子函数。
  • onDeactivated:当组件被停用时调用,对应Vue组件的onDeactivated钩子函数。

当一个组件实例从DOM上移除但因为被<KeepAlive>缓存而仍作为组件树的一部分时,它将变为不活跃状态而不是被卸载。当一个组件实例作为缓存树的一部分插入到DOM中时,它将重新被激活。

<script setup>
import { onActivated, onDeactivated } from 'vue'
onActivated(() => {
  // 在组件被激活时执行的操作
  // 调用时机为首次挂载
  // 以及每次从缓存中被重新插入时
})
onDeactivated(() => {
  // 在组件失效时执行的操作
  // 在从 DOM 上移除、进入缓存
  // 以及组件卸载时调用
})
</script>

onActivated在组件挂载时也会调用,并且onDeactivated在组件卸载时也会调用。这两个钩子不仅适用于KeepAlive缓存的根组件,也适用于缓存树中的后代组件。

八、举个例子

让我们通过一个实际的案例来演示KeepAlive的使用。假设我们有一个选项卡切换的页面,每个选项卡对应一个组件。

<template>
  <div>
    <button @click="toggleTab('TabA')">Tab A</button>
    <button @click="toggleTab('TabB')">Tab B</button>
    <KeepAlive>
      <component :is="currentTab"></component>
    </KeepAlive>
  </div>
</template>
<script>
import ComponentA from './ComponentA.vue';
import ComponentB from './ComponentB.vue';
export default {
  components: {
    ComponentA,
    ComponentB
  },
  data() {
    return {
      currentTab: 'ComponentA'
    };
  },
  methods: {
    toggleTab(tab) {
      this.currentTab = tab;
    }
  }
}
</script>

<KeepAlive>标签中,我们使用了动态组件来根据currentTab的值来动态渲染不同的组件。

toggleTab方法用于切换当前的选项卡。当按钮被点击时,会调用该方法,并将对应的选项卡名称作为参数传入。该方法会将currentTab的值更新为传入的选项卡名称,从而实现动态切换选项卡的效果。

九、最后的话

KeepAlive是Vue提供的一个强大工具,能够显著提升应用程序的性能和用户体验。通过合理地运用KeepAlive,我们可以在保持组件状态的同时,提供快速、流畅的用户界面切换效果。

如果对Vue中的插槽(slot)有不清楚,可以去看这篇 Vue中的插槽(Slot)技术详解!

到此这篇关于详解如何优雅运用Vue中的KeepAlive组件的文章就介绍到这了,更多相关Vue KeepAlive组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue如何监听页面缓存事件

    vue如何监听页面缓存事件

    这篇文章主要介绍了vue如何监听页面缓存事件,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • 深入理解Vue 的钩子函数

    深入理解Vue 的钩子函数

    这篇文章主要介绍了Vue 的钩子函数,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • 羊了个羊通关脚本Vue node实现版本

    羊了个羊通关脚本Vue node实现版本

    这篇文章主要为大家介绍了羊了个羊通关脚本Vue node实现版本,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • vue2.0组件之间传值、通信的多种方式(干货)

    vue2.0组件之间传值、通信的多种方式(干货)

    这篇文章主要介绍了vue2.0组件之间传值、通信的多种方式以及注意要点,需要的朋友可以参考下
    2018-02-02
  • vue中如何引入jest单元测试

    vue中如何引入jest单元测试

    这篇文章主要介绍了vue中如何引入jest单元测试问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • axios请求头设置常见Content-Type和对应参数的处理方式

    axios请求头设置常见Content-Type和对应参数的处理方式

    这篇文章主要介绍了axios请求头设置常见Content-Type和对应参数的处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Vue 事件处理函数的绑定示例详解

    Vue 事件处理函数的绑定示例详解

    这篇文章主要为大家介绍了Vue 事件处理函数的绑定示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • Vue导入Echarts实现折线散点图

    Vue导入Echarts实现折线散点图

    这篇文章主要为大家详细介绍了Vue导入Echarts实现折线散点图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • vue3+vite加载本地js/json文件不能使用require浅析

    vue3+vite加载本地js/json文件不能使用require浅析

    这篇文章主要给大家介绍了关于vue3+vite加载本地js/json文件不能使用require的相关资料,require 是属于 Webpack 的方法,在v3+vite的项目里面并不适用,需要的朋友可以参考下
    2023-07-07
  • vue中如何使用echarts动态渲染数据

    vue中如何使用echarts动态渲染数据

    这篇文章主要给大家介绍了关于vue中如何使用echarts动态渲染数据的相关资料,echarts是一款基于JavaScript的开源可视化图表库,它通过简单的配置即可实现各种各样的可视化效果,需要的朋友可以参考下
    2023-11-11

最新评论