Vue keep-alive概述

当使用动态组件时,当您切换:is指令的值时,Vue会重新创建组件的新实例。尽管它在大多数情况下很有用,但有时我们想要保存隐藏元素的状态。

使用Vue keep-alive 的组件。

根据您的项目,Vue Keep-Alive组件可以是提高速度并提供更好的用户体验的好方法。

这是VueJS中更高级的主题,因此我假设您在Vue中有一些背景知识。

什么是Keep-Alive

为了了解keep-alive状态,您首先必须了解什么是动态组件。简而言之,可以使用v-bind:is指令在不同组件之间切换。

最常见的示例是Tab系统,其中根据打开的TAB,内容切换到其他组件。

通常,当您在动态组件之间切换时,Vue会创建一个全新的组件实例。

但是,Vue keep-alive是围绕动态组件的包装器元素。当它处于非活动状态时,它将存储对组件的缓存引用。这意味着Vue不必每次切换组件时都创建一个新实例。

取而代之的是,只要您返回它,它就只使用缓存的引用。

VueJS称Keep-Alive为抽象元素-意味着它不呈现DOM元素,也不显示为组件。

“Keep-Alive”有用吗?

在大多数情况下,动态组件的内置功能非常好。在某些情况下,您可能想要缓存状态,例如:

  • 将用户输入缓存在表单上,阅读进度等。
  • 您的组件进行了大量的API调用,而您只想进行一次
  • 您的组件需要一些时间来设置数据和计算的属性,因此您想在它们之间快速切换

像VueJS或任何编程语言中最高级的主题一样,我不能告诉您何时/何时不使用keep-alive组件的确切答案。无论选择什么,只要确保知道为什么要使用某种代码设计即可。

如何使用它

在您的Vue项目中,让我们看一下动态组件系统,以了解keep-alive的组件何时有用。假设我们有一个父Tabs组件,它有两个子组件-About和Contact。

  • 关于组件将仅具有静态内容
  • 联系人页面将有一个文本输入和一个按钮

另外,我添加了一些控制台消息,以便我们了解发生了什么。

让我们从创建这些组件开始。

About.vue



Contact.vue



为了了解keep-alive组件的目的,我们将首先实现Tabs组件而不使用它们。只需使用典型的动态组件设置即可完成。

简而言之,此组件具有两个按钮,用于切换动态组件。

Tabs.vue



现在,如果您运行您的应用程序,您应该会看到类似这样的信息。

很简单,我知道,但要点很明确。

在组件之间切换时,您应注意以下几点:

  • 每次切换选项卡时,来自mount()的消息都会打印在控制台中
  • 如果在“联系人”中填写输入,然后切换选项卡,则返回时,您的输入将不存在。

这两个都是因为没有keep-alive状态,Vue会创建组件的新实例,因此所有生命周期hooks都会重新运行,并且您所做的任何输入都会丢失。

现在,让我们实现keep-alive状态。

好的。这将非常容易。

转到您的Tabs.vue父组件。您所要做的就是将动态组件包装成这样的keep-alive元素。

Tabs.vue


   

现在,与以前相比,您的标签系统应具有以下功能:

  • 来自mount()的消息应该由每个组件打印一次,并且只能打印一次
  • 如果您在“联系人”选项卡上填写了输入,则在切换选项卡并返回时,该输入仍应存在

虽然这是使用keep-alive组件的简单用例,但它是说明为什么要使用它们的一个很好的例子。

keep-alive具有自定义hook

关于keep-alive的组件的一件整洁的事情是,它们具有特殊的Vue生命周期hooks。这是必需的,因为keep-alive状态的组件仅运行一次其初始化hooks(创建和挂载)。

为了帮助观察何时切换keep-alive的组件,我们有两个独特的hook-这两个hook都很直观:

  • .activated() –激活keep-alive的组件时调用
  • .deactivated() –当您猜到它被停用时,会调用此函数

让我们用前面的示例实现这些hooks,以便在切换组件时将其输出到控制台。

我们可以像在VueJS中添加任何其他生命周期hook一样添加这些hook。它看起来像这样。假设我们正在编辑About.vue组件。

About.vue

mounted() {
    console.log('About has been mounted')
},
activated () {
    console.log('About has been activated')
},
deactivated () {
    console.log('About has been deactivated')
}

现在,如果我们运行我们的应用程序并在选项卡之间切换,我们将看到挂载的消息仅打印一次,而激活/停用的消息则重复打印。

要注意的一件事是,当动态组件首次显示时,它既已安装又被激活。因此,确保您不会两次计算某些逻辑很重要。

利弊

当然,使用keep-alive而不只是默认的动态组件是有利有弊。

  • 优点:存储组件缓存,更快的组件
  • 缺点:容易过度使用,通常情况下已经足够好了。

对于大多数用途,仅使用默认的动态组件而无需keep-alive状态是最佳解决方案。但是,如果您想轻松保存用户状态,则keep-alive状态组件是完成此操作的超级简单方法。

就像我在上面写的那样,无论您是否选择使用keep-alive的组件,了解它们如何工作都是很有用的。建立您的编程知识工具集从来都不是一件坏事。

包裹起来…

keep-alive组件是一种非常简单的开始使用的技术。最简单的形式就是将一个wrapper元素添加到动态组件中。

保存状态并在动态组件之间快速切换非常有用。

参考

An Overview of Vue Keep-Alive

你可能感兴趣的:(Vue keep-alive概述)