每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会
1.• 创建阶段: new Vue({})
1.实例初始化|生命周期• beforeCreate:执行第一个生命周期。 | 只可以得到 vue 实例 、 数据 $el dom 都没有更新
2.注入反应内容• created: 实例创建后调用。 | 数据 方法初始化完成 、 $el dom 没有更新
3.绑定没绑定el 执行对应的模版
2.• 挂载阶段
4.• beforeMount:实例挂载之前调用,结束之后获取el Dom。 | 数据 方法初始化完成 得到$el 、 dom得到虚拟DOM
• mounted: 实例挂载完毕。 | 所有内容渲染完成 得到 数据 方法 el DOM
特点:每个实例只能执行一次。
3.• 运行阶段:
• beforeUpdate:数据更新后显示,视图更新前调用。 | DOM 没有得到更新
• updated: 视图更新后调用。 | 视图更新后 运行阶段 更新完
• 特点:按需调用
4.• 销毁阶段:
• beforeDestroy:实例销毁之前调用。 | 销毁前 最后一次能获取到数据的位置
• destroyed: 实例销毁后调用。 | 销毁后 拿不到 vue 实例
特点:每个实例只能执行一次。