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

动态组件指的是动态切换组件的显示与隐藏。 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>
毕业16个工作日,平均薪资13180元,就业率100%,广州黑马AI智能应用开发(Java)学科20250529班
2026-03-06毕业32个工作日,平均薪资11147元,就业率95%,广州黑马AI智能应用开发(Java)学科20250326班
2026-03-05黑马程序员2025全国就业数据发布:全学科平均就业率92.07%,AI开发类就业平均薪资达11869.67元。
2026-03-05黑马全国校区齐开班!场面太太太壮观了!
2026-03-03AI智能应用开发课程紧贴企业刚需,全程高效学习,直达中高级软件开发水平
2026-02-28风口正劲!黑马程序员又一AI智能应用开发班毕业当天100%就业!
2026-02-27