vue父组件监听子组件生命周期

本文介绍了在Vue中如何实现父子组件之间的通信,包括子组件触发父组件的方法以及父组件监听子组件生命周期的方法。主要涉及`$emit`事件触发和`@hook`监听生命周期钩子,如`created`和`mounted`,展示了两种不同的通信和监听策略。
摘要由CSDN通过智能技术生成

1、子组件

<template>
<div>子组件</div>
</template>
<script>
export default {
  data () {
    return {

    }
  },
  created () {
    /**
     * 方法二
     * 通过@hook 监听 @hook:created="parentMethods2"(created是子组件生命周期)
     * 父组件事件parentMethods2监听到了子组件生命周期created
     */
  },
  mounted () {
    /**
     * 方法一
     * 子组件触发父组件的方法通过绑定事件(@methods1="parentMethods1")
     * 在子组件使用this.$emit('methods1')触发此事件
     */
    this.$emit('methods1')
  }
}
</script>
<style scoped lang="less">

</style>

2、父组件

<template>
<div>

  <Child @hook:created="parentMethods2" @methods1="parentMethods1"/>
</div>
</template>
<script>

/**
 * 方法一 @methods1="parentMethods1
 * 有父组件 Parent 和子组件 Child,如果父组件监听到子组件挂载 mounted 就
 * 做一些逻辑处理,可以通过以下写法实现
 *
 * 方法二  @hook:created="parentMethods2"
 * 更简单的方式可以在父组件引用子组件时通过 @hook 来监听即可
 * @hook 方法不仅仅是可以监听 mounted,其它的生命周期事件,
 * 例如:created,updated 等都可以监听。
 */
import Child from './child'
export default {
  components: {
    Child
  },
  methods: {
    parentMethods1 () {
      console.log('父组件监听到子组件 mounted 钩子函数 ...')
    },
    parentMethods2 () {
      console.log('父组件监听到子组件 mounted 啦 ...')
    }
  }
}
</script>
<style scoped lang="less">

</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值