vue-生命周期详解

 

1.首先清楚除了keep-alive相关的两个生命周期(activityed&deactivityed)以外一共有几个生命周期钩子:beforeCreate、created、beforemount、mounted、beforeupdate、updated、beforedestroy、destroyed

 

具体流程如下:从new Vue()开始执行,执行了很多初始化的操作。

 

1.当执行完initLifecycle()、initEvents()、initRender()。会触发beforeCreate()

2.紧接着会执行initInjections()、initState()、initProvide()。这些执行完毕后会触发created()钩子,我们常说在这个阶段可以获取到data中的数据是因为initState()这个初始化阶段进行了data、props、computed 的处理。所以才能拿到

3.由于上面一些初始化的工作已经做完了,接下来要进行组件挂载的工作了。那么在执行mountComponent()函数的初期,会触发beforeMounte()钩子。

4.当挂载完毕之后,我们会进行判断,如果你是根组件(也就是vue实例),那么会在mountComponent()函数的结尾触发mounted()钩子

5.但如果你是子组件的话,我们会在createEle()和createComponent()中都会有相关代码是处理钩子函数的,也就包括mounted()钩子的处理

6.当然这里有一个新的问题就是:会发现子组件的mounted优先于父组件的mounted执行,因为从源码可以看到子组件的vnode会优先添加到队列里面

7.在执行mounteCompoent()的时候会定义一个Watcher,beforeUpdate和updated都和这个Watcher有关,并且在初始化阶段是不会执行update的,只有在数据发生变化的时候才会去触发他,这里和响应式原理有关

8.destroy也就是组件销毁的时候了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lar_slw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值