更新时间: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>
【AI设计】北京143期毕业仅36天,全员拿下高薪offer!黑马AI设计连续6期100%高薪就业
2025-09-19【跨境电商运营】深圳跨境电商运营毕业22个工作日,就业率91%+,最高薪资达13500元
2025-09-19【AI运维】郑州运维1期就业班,毕业14个工作日,班级93%同学已拿到Offer, 一线均薪资 1W+
2025-09-19【AI鸿蒙开发】上海校区AI鸿蒙开发4期5期,距离毕业21天,就业率91%,平均薪资14046元
2025-09-19【AI大模型开发-Python】毕业33个工作日,就业率已达到94.55%,班均薪资20763元
2025-09-19【AI智能应用开发-Java】毕业5个工作日就业率98.18%,最高薪资 17.5k*13薪,全班平均薪资9244元
2025-09-19