首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue 父组件如何监听子组件的生命周期

Vue 父组件如何监听子组件的生命周期

作者头像
Leophen
发布2020-10-14 09:56:35
1.5K0
发布2020-10-14 09:56:35
举报

一、通过 $emit 实现

这里以 mounted 为例,在父组件 Parent 和子组件 Child 中,如果父组件监听到子组件挂载 mounted 就做一些逻辑处理,可以通过以下写法实现:

// Parent.vue
<Child @mounted="doSomething"/>
    
// Child.vue
mounted() {
  this.$emit("mounted");
}

以上方法虽然可行,但每次都需要手动写一次 $emit 触发父组件的事件 更简单的方式可以在父组件引用子组件时通过 @hook 来监听生命周期

二、通过 @hook 实现

还是父组件 Parent 和子组件 Child,@hook 的写法如下:

//  Parent.vue
<Child @hook:mounted="doSomething" ></Child>

doSomething() {
   console.log('父组件监听到 mounted 钩子函数 ...');
},
    
//  Child.vue
mounted(){
   console.log('子组件触发 mounted 钩子函数 ...');
},    
    
// 以上输出顺序为:
// 子组件触发 mounted 钩子函数 ...
// 父组件监听到 mounted 钩子函数 ...     

当然 @hook 方法不仅仅是可以监听 mounted,其它的生命周期事件,例如:created,updated 等都可以监听

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、通过 $emit 实现
  • 二、通过 @hook 实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档