Vue的生命周期

1.生命周期是什么?

Vue的生命周期是指Vue实例从创建到销毁的过程,即指从创建、初始化数据、编译模板、挂载DOM、数据变化渲染更新到DOM上、销毁等一系列过程。

2.生命周期有哪些?

Vue的生命周期总共可以分为8个阶段:创建前后,载入前后,更新前后,销毁前后,以及一些特殊场景的生命周期。

生命周期 描述
beforeCreate 组件实例创建之初
created 组件实例已经完全创建
beforeMounted 组件挂载之前
mounted 组件挂载到实例上去之后
beforeUpdate 组件数据发生变化,更新之前
updated 组件数据更新之后
beforeDestory 组件实例销毁之前
destoryed 组件实例销毁之后
activated keep-alive缓存的组件激活时
deactivated keep-alive缓存的组件停用时调用

在Vue生命周期钩子函数中会自动绑定this上下文到实例中,因此可以生命周期钩子函数中访问数据,运行方法。

3.生命周期的整体流程

具体分析

beforeCeated → created

  • 初始化Vue实例,进行数据观测

created

  • 完成数据观测,属性与方法的运算,watchevent事件回调的配置
  • 可调用methods中的方法,访问和修改data数据触发响应式渲染dom,可通过computedwatch完成数据计算
  • 此时vm.$el并没有被创建

created → beforeMount

  • 判断是否存在el 选项,若不存在则停止编译,直到调用vm.$mount(el)才会继续编译
  • 优先级:render > template > outerHTML
  • vm.el获取到的是挂载DOM

mounted

  • vm.el已经完成DOM的挂载和渲染,此刻打印vm.$el,发现之前的挂载点及内容被替换成新的DOM

beforeUpdate

  • 更新的数据必须是被渲染在模板上的(elrendertemplate 之一)
  • 此时view层还未更新
  • 若在beforeUpdate中再次修改数据,不会再次触发更新方法

updated

  • 完成view层的更新
  • 若在updated中再次修改数据,会再次触发更新方法(beforeUpdateupdated

beforeDestory

  • 实例被销毁前调用,此时实例属性与方法仍可访问

destroyed

  • 完全销毁一个实例。可清理它与其他实例之间的连接,解绑它的全部指令及事件监听器
  • 并不能清除DOM,仅仅销毁实例

使用场景

题外话:数据请求在created还是mounted?

一般来说,在createdmounted中都可以发送数据请求。但是大部分时候会在created中发送请求。
created是在组件实例一旦创建完成立即调用,此时页面dom节点并未生成。
mounted是在页面dom节点渲染完毕之后立即执行,此时页面dom节点已经生成。

在触发时机上createdmounted更早,二者都能拿到实例对象的属性和方法。
放在mounted中请求数据有可能导致页面闪动(页面dom结构已经生成,页面dom会进行二次渲染),在created就不会出现此类情况。

建议:放在created中去请求数据

文章作者: qinwei
文章链接: https://qw-null.github.io/2022/07/28/Vue的生命周期/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 QW's Blog