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

<template>
  <div>
    Hello From the About Page!
  </div>
</template>
<script>
export default {
  mounted() {
    console.log('About has been mounted')
  }
}
</script>

Contact.vue

<template>
  <div>
    <input type='text' placeholder='Enter your Message' />
    <input type='button' value="Send" />
  </div>
</template>
<script>
export default {
  mounted() {
    console.log('Contact has been mounted')
  }
}
</script>

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

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

Tabs.vue

<template>
  <div>
    <button v-for='tab in tabs' :key='tab' @click='component = tab'>
      {{tab}}
    </button>
    <component :is='component' />
  </div>
</template>
<script>
import About from "@/components/2019/keep-alive/About.vue";
import Contact from "@/components/2019/keep-alive/Contact.vue";
export default {
  components: { About, Contact },
  data () {
    return {
      tabs: ["About", "Contact"],
      component: "About"
    }
  }
}
</script>

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

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

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

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

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

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

好的。这将非常容易。

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

Tabs.vue

<keep-alive>
   <component :is='component' />
</keep-alive>

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

  • 来自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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,204评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,091评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,548评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,657评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,689评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,554评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,302评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,216评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,661评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,851评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,977评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,697评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,306评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,898评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,019评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,138评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,927评论 2 355

推荐阅读更多精彩内容