4个阶段:
初始化阶段:beforeCreate和created
挂载阶段:beforeMount和mounted
更新阶段:beforeUpdate和updated
销毁阶段:beforeDestroy和destroyed
缓存:activated和deactivated
初始化阶段:
初始化全局组件=>初始化父子关系树=>初始化自定义组件的自定义事件=>初始化插槽信息和得到h函数=>调用beforeCreate生命周期=>初始化initInjections=>初始化state(props、methods、data、computed、watch)=>初始化Provide =>调用created生命周期=>进入挂载阶段
我们在beforeCreate里拿不到props、methods、data、computed、watch
在created里可以拿到props、methods、data、computed、watch
挂载阶段:
通过compile去解析templated的到AST语法树=>调用beforeMount生命周期=>updateComponent=>绑定观察者Watcher=>调用mounted生命周期
updateComponent的核心是对通过compile解析templated的到AST语法树进行转换成真实DOM然后渲染到页面
解析和过程:
AST语法树通过h函数抽离出VNode(虚拟DOM)=> 通过diff算法的patch函数将VNode变换成真实DOM渲染到页面
注意:VNode的顺序是子在前父在后 父子生命周期执行顺序:父beforeCreate=>created=>beforeMount=>子beforeCreate=>created=>beforeMount=>mounted=>父mounted
更新阶段:
对挂载阶段绑定的观察者Watcher进行触发=>挂载阶段绑定Watcher时会传入before方法before方法内主要就是调用beforeUpdate生命周期 当数据改变时Watcher会先触发before方法然后触发Watcher自身的update方法在处理完数据变更后会调用updated生命周期
销毁阶段:
将实例从其父级实例中删除=>移除实例的依赖=>移除实例内响应式数据的引用=>删除子组件实例。
缓存:
场景模拟:tab切换
当keep-alive中的组件被点击时,activated生命周期函数被激活执行一次,切换到其它组件时,deactivated被激活。如果没有keep-alive包裹,没有办法触发activated生命周期函数。