# Vue动态组件

说明

多个组件使用同一个挂载点,并动态切换,这就是动态组件。

# 概述

通过使用保留的 <component> 元素,动态地绑定到它的 is 特性,可以实现动态组件。

# 缓存

<keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition> 相似,<keep-alive> 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。

TIP

<div id="example">
  <button @click="change">切换页面</button>
  <keep-alive>
    <component :is="currentView"></component>  
  </keep-alive>
</div>
<script>
new Vue({
  el: '#example',
  data:{
    index:0,
    arr:[
      {template:`<div>我是主页</div>`},
      {template:`<div>我是提交页</div>`},
      {template:`<div>我是存档页</div>`}
    ],
  },
  computed:{
    currentView(){
        return this.arr[this.index];
    }
  },
  methods:{
    change(){
      let len = this.arr.length;
      this.index = (++this.index)% len;
    }
  }
})
</script>

# 条件判断

如果有多个条件性的子元素,<keep-alive> 要求同时只有一个子元素被渲染

<div id="example">
  <button @click="change">切换页面</button>
  <keep-alive>
    <home v-if="index===0"></home>
    <posts v-else-if="index===1"></posts>
    <archive v-else></archive>  
  </keep-alive>
</div>

# activated和deactivated

activateddeactivated<keep-alive> 树内的所有嵌套组件中触发。

TIP

当组件被激活时,触发钩子函数 activated,当组件被移除时,触发钩子函数 deactivated。

# include和exclude

includeexclude 属性允许组件有条件地缓存。二者都可以用逗号分隔字符串正则表达式或一个数组来表示

TIP

exclude 的优先级比 include 高

<!-- 逗号分隔字符串 -->
<keep-alive include="a,b">
  <component :is="view"></component>
</keep-alive>
<!-- 正则表达式 (使用 v-bind) -->
<keep-alive :include="/a|b/">
  <component :is="view"></component>
</keep-alive>
<!-- Array (use v-bind) -->
<keep-alive :include="['a', 'b']">
  <component :is="view"></component>
</keep-alive>
Last Updated: 1/10/2023, 11:26:43 PM