Vue生命周期

什么是生命周期:

从Vue实例创建、运行、到销毁期间,总是伴随着各种各样的事件,这些事件,统称为生命周期!生命周期钩子:就是生命周期事件的别名而已;生命周期钩子 = 生命周期函数 = 生命周期事件

主要的生命周期函数分类:

创建期间的生命周期函数:

  • beforeCreate:实例刚在内存中被创建出来,此时,还没有初始化好 data 和 methods 属性
  • created:实例已经在内存中创建OK,此时 data 和 methods 已经创建OK,
    • 如果要调用methods中的方法或操作data中的数据,最早只能在created中操作
    • 此时还没有开始编译模板
  • beforeMount:此时已经完成了模板的编译,但是还没有挂载到页面中
    • 这个函数执行的时候模板已经在内存中编译好了,但尚未挂在到内存中去,页面上还是原数据。
  • mounted:此时,已经将编译好的模板,挂载到了页面指定的容器中显示
    • 在这里已经渲染好页面了,如果要操作DOM节点最早在mounted中进行

运行期间的生命周期函数:

  • beforeUpdate:状态更新之前执行此函数, 此时 data 中的状态值是最新的,虚拟DOM也是最新的,但是界面上显示的真实DOM数据还是旧的。data和页面的数据并不是一致的,因为此时还没有开始重新渲染DOM节点
  • updated:实例更新完毕之后调用此函数,此时 data 中的状态值 和 界面上显示的数据,都已经完成了更新,界面已经被重新渲染好了!页面和data的值都已经一致了

销毁期间的生命周期函数:

  • beforeDestroy:实例销毁之前调用。在这一步,实例仍然完全可用。
  • destroyed:Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。
    每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会

注意:

不要在选项属性或回调上使用箭头函数,比如 created: () => console.log(this.a)vm.$watch('a', newValue => this.myMethod())。因为箭头函数并没有 thisthis 会作为变量一直向上级词法作用域查找,直至找到为止,经常导致 Uncaught TypeError: Cannot read property of undefinedUncaught TypeError: this.myMethod is not a function 之类的错误。

在这里插入图片描述

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、生命周期概念 首先,每一个vue实例都有一个完整的生命周期,主要分为五个阶段:创建、初始化、渲染、运行、销毁。...
    益码凭川阅读 7,545评论 0 0
  • 一般说的 Vue 生命周期指的是打包完成后的 js 代码去执行的过程,区别于开发环境和 HTML 嵌入 Vue.j...
    Wermdany阅读 4,765评论 1 2
  • [vue实例的生命周期](https://cn.vuejs.org/v2/guide/instance.html ...
    小棋子js阅读 1,625评论 0 0
  • Vue 实例 在文档中经常会使用 vm 这个变量名表示 Vue 实例,在实例化 Vue 时,需要传入一个选项对象,...
    鄙人才疏学浅阅读 3,660评论 0 1
  • 今天没有什么特别的事,就是工作而已啦!但是吃了李子。 然后呢?因为一整天都在工作,所以也就没有学些什么。 但是今天...
    薛灵均阅读 806评论 0 1