美文网首页
Vue keep-alive概述

Vue keep-alive概述

作者: 魂斗驴 | 来源:发表于2021-04-22 09:13 被阅读0次

    当使用动态组件时,当您切换: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

    相关文章

      网友评论

          本文标题:Vue keep-alive概述

          本文链接:https://www.haomeiwen.com/subject/nnymkltx.html