首页技术文章正文

Vue如何实现动态组件渲染?

更新时间:2022-09-15 来源:黑马程序员 浏览量:

IT培训班

动态组件指的是动态切换组件的显示与隐藏。 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>





分享到:

Java培训班课程javaee

Python培训机构python大数据

web前端培训课程升级V8.5web

AI+设计培训课程ui

大数据培训课程cloud

软件测试培训课程test

c

新媒体运营培训netmarket

产品经理培训课程pm

linux培训Linux

movies

智能机器人培训robot

电商视觉设计课程uids

AI

集成电路应用开发(嵌入式)培训课程jdbc

在线咨询 我要报名
和我们在线交谈!