
深入Vue.js:父组件控制子组件v-if的渲染机制
在Vue.js应用中,常使用props传递数据,控制子组件的显示/隐藏。本文重点分析:父组件通过props控制子组件根元素的v-if指令,子组件渲染过程及生命周期变化。
父组件传递布尔值visible给子组件,控制其根元素的v-if。这与直接在父组件使用v-if控制子组件实例化不同。
父组件示例中,按钮切换visible值,从而控制子组件显示。子组件接收visible作为props,应用于根元素的v-if。
立即学习“前端免费学习笔记(深入)”;
千帆AppBuilder
百度推出的一站式的AI原生应用开发资源和工具平台,致力于实现人人都能开发自己的AI原生应用。
174 查看详情
初始状态visible为false,子组件未显示。然而,开发者工具显示子组件生命周期钩子已全部执行一次。这与预期(v-if为假,组件不创建)不同。
关键区别在于:通过props控制子组件根元素v-if,与父组件直接用v-if控制子组件实例化不同。前者仅控制子组件根元素渲染,visible为false时,组件实例仍然存在,只是内容不显示。因此,子组件生命周期钩子在组件实例创建时执行一次,而非v-if条件变化时重复执行。
若在父组件使用v-if直接控制子组件,则情况不同。v-if为false时,子组件实例被销毁;为true时,创建新实例,导致生命周期钩子在条件切换时执行。
因此,使用props控制子组件根元素v-if,组件实例创建和销毁只发生一次,v-if仅控制DOM元素渲染,而非组件实例生命周期。 需监听visible变化并执行操作,可在子组件内使用watch监听visible属性变化。
以上就是Vue子组件根元素v-if:父组件控制显示隐藏时,子组件生命周期如何变化?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1131524.html
微信扫一扫
支付宝扫一扫