动态组件
实现动态组件渲染
vue提供给一个内置的component组件,专门用来实现动态组件的渲染
//通过 is 属性,动态指定要渲染的组件
<component :is="comName"></component>
//点击按钮,动态切换组件的名称
<button @click="comName = 'Left'">展示 Left 组件</button>
<button @click="comName = 'Right'">展示 Right 组件</button>
data() {
return {
//当前要渲染的组件名称
comName: 'left'
}
}
component标签为vue内置,作用为组件的占位符
is属性的值表示要渲染的组件的名称
is属性的值,应该是组件在components节点下的注册名称
keep-alive
通过component标签动态渲染的组件,在切换时会进行销毁,当切换回来时才重新创建
因此其中的数据并不会保留
此时可以通过keep-alive标签包过进行缓存,保证组件不被销毁
<keep-alive>
<component :is="comName"></component>
</keep-alive>
默认在keep-alive标签内包裹的所有组件都不会销毁
可以通过添加属性进行修改
include
include属性用来指定只有名称匹配的组件会被缓存,多个组件名之间使用英文逗号分隔
<keep-alive include="MyLeft">
<!-- 此时include中的值为名称匹配的组件,
当组件export default中没有name属性时include的值为组件注册时的名称,
当组件export default中有name属性时include的值就必须为name属性的值 -->
<component :is="comName"></component>
</keep-alive>
此时只有include中的组件才会被缓存,其他按默认进行销毁创建
exclude
exclude属性用来指定哪些组件不需要被缓存,多个组件名之间使用英文逗号分隔
<keep-alive exclude="MyRight">
<!-- 此时exclude中的值为名称匹配的组件,
当组件export default中没有name属性时exclude的值为组件注册时的名称,
当组件export default中有name属性时exclude的值就必须为name属性的值 -->
<component :is="comName"></component>
</keep-alive>
此时只有exclude中的组件不会被缓存,其他按默认进行缓存
注: include与exclude这两个属性不能同时使用
正则
include和exclude属性还支持多种写法
<!-- 逗号分隔字符串 -->
<keep-alive include="a,b">
<component :is="comName"></component>
</keep-alive>
<!-- 正则表达式(使用'v-bind') -->
<keep-alive :include="/a|b/">
<component :is="comName"></component>
</keep-alive>
<!-- 数组(使用'v-bind') -->
<keep-alive :include="['a', 'b']">
<component :is="comName"></component>
</keep-alive>
注:
include和exclude的值为组件自身的name属性 (并非引入时的命名,是组件内部的name属性)
如果name属性选项不可用,才匹配它的局部注册名称(父组件components选项的键值)
匿名组件不能被匹配
keep-alive对应的生命周期函数
keep-alive会对组件进行缓存及激活,同样具有生命周期函数
当组件被缓存时,会自动触发组件的deactivated生命周期函数
当组件被激活时,会自动触发组件的activated生命周期函数