云和教育:云和数据集团旗下高端ICT职业教育品牌
  • 国家级全民数字素养与技能培训基地
  • 河南省第一批产教融合型企业建设培育单位
  • 郑州市数字技能人才(码农)培养评价联盟

Vue动态组件渲染是怎么实现的?

  • 作者:云和教育
  • 日期:2023-03-08
  • 浏览:398次

动态组件指的是动态切换组件的显示与隐藏。 vue 提供了一个内置的<component>组件,专门用来实现动态组件的渲染。示例代码如下:

data() {  //1.当前要渲染的组件名称  return { comName:'Left'}}<!--2.通过is属性,动态指定要渲染的组件--><component :is="comName"></component><!--3.点击按钮,动态切换组件的名称--><button @click="comName='Left'">展示 Left 组件</button><button @click="comName='Right'">展示 Right 组件</button>

默认情况下,vue切换动态组件时无法保持组件的状态。此时可以使用 vue 内置的 组件保持动态组件的状态,示例代码如下:

<keep-alive>  <component :is="comName"></component></keep-alive>

keep-alive 对应的生命周期函数

当组件被缓存时,会自动触发组件的 deactivated 生命周期函数。当组件被激活时,会自动触发组件的 activated 生命周期函数。

export default {  crkated(){ console.log('组件被创建了') },  destroyed(){console.log('组件被销毁了')},    activated(){console.log('Left组件被激活了!')},  deactivated(){console.log('Left组件被缓存了!') }}

keep-alive 的 include 属性

include 属性用来指定:只有名称匹配的组件会被缓存。多个组件名之间使用英文的逗号分隔:

<keep-alive include="MyLeft,MyRight">  <component :is="comName"></component></keep-alive>