vue父子组件生命周期执行顺序_vue父子组件生命周期执行顺序

之前写了vue的生命周期,本以为明白了vue实例在创建到显示在页面上以及销毁等一系列过程,以及各个生命周期的特点。然而今天被问到父子组件生命周期执行顺序的时候一头雾水,根本不知道怎么回事。然后写了一段demo验证一下大佬们说的顺序。

Document

var login ={

template:'

{{childMsg}}}

',

data(){return{

childMsg:'child'}

},

beforeCreate:function() {debugger;

console.log("子组件的beforeCreate")

},

created:function() {debuggerconsole.log("子组件的created")

},

beforeMount:function() {debuggerconsole.log("子组件的beforeMount")

},

mounted:function() {debuggerconsole.log("子组件的mounted")

}

}var vm = newVue({

el:'#app',

data: {

fatherMsg:"father"},

methods: {},

components: {

login

},

beforeCreate:function() {debuggerconsole.log("父组件的beforeCreate")

},

created:function() {debuggerconsole.log("父组件的created")

},

beforeMount:function() {debuggerconsole.log("父组件的beforeMount")

},

mounted:function() {debuggerconsole.log("父组件的mounted")

},

});

运行此代码,打开f12,进入sources里边

1.首先执行的是父组件的beforeCreate

2.执行的是父组件的created周期

3.执行的是父组件的beforeMount周期

4.执行的是子组件的beforeCreate周期

5.执行的是子组件的created周期

6.执行的是子组件的beforeMount周期

7.执行的是子组件的mounted周期

8.执行的是父组件的mounted周期

总结:

通过上边一步步的debugger,我们可以发现父子组件在加载的时候,执行的先后顺序为父beforeCreate->父created->父beforeMount->子beforeCreate->子created->子beforeMount->子mounted->父mounted。

然后我们通过控制台打印的结果进一步证实了这个顺序。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值