博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vue学习笔记(2)—— Vue的生命周期
阅读量:6282 次
发布时间:2019-06-22

本文共 993 字,大约阅读时间需要 3 分钟。

(转自)面试碰到这个问题了,回想一下,很多问题都是写代码的时候碰到了随查随写缺少总结,真到了要说点什么的时候就说的乱七八糟,那么这次就来捋一捋Vue的生命周期

生命周期,就是Vue实例在被创建之前要经过一系列的初始化过程。首先,放一张Vue官网的生命周期图示。

图示中可以看到,Vue的生命周期中顺序的包含了以下几个生命周期钩子,然后结合生命周期我们逐一讨论:

  • beforeCreate
  • created
  • beforeMount
  • mounted
  • beforeUpdate
  • updated
  • beforeDestroy
  • destroyed

1. beforeCreate

在这个生命周期,组件实例刚刚被创建但尚未创建完成,而组件属性如$eldata等都还没有计算。

2. created

组件实例已创建完成,data等属性已绑定完成,但DOM尚未生成,$el 属性还不存在

3. beforeMount

即模板编译、挂载之前,这个生命周期,首先会判断是否存在el选项,存在则继续编译,否则停止编译、生命周期暂停直到调用vm.$mount(el)方法才会继续向下编译,这个el参数就是挂载的DOM节点。 接下来会判断是否存在template选项,存在则将其作为模板编译成render函数,否则将el的外部HTML作为模板编译。

另外vue对象中存在一个render函数,它的优先级大于template。

4. mounted

即模板编译、挂载之后,这里会给vue实例对象添加$el成员,并且替换掉挂载的DOM元素。举例而言,我们写在页面的<div>{

{msg}}</div>是在这里把实例里的msg值渲染上去的。

5. beforeUpdate

data的数据发生改变时,会触发对应组件的重新渲染,这时可以检测到data变化但是view还没有重新渲染。

6. updated

view层被重新渲染,数据更新。

6. beforeDestroy

beforeDestroy在实例被销毁之前,这时实例仍然完全可用。

7. destroyed

destroyed 在实例被销毁之后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。


生命周期就讨论到这里了,觉得比较抽象的盆友可以自己写demo测试一下,会更直观一些,或者参考一下更详细的文章把。

参考文章:

转载地址:http://pfova.baihongyu.com/

你可能感兴趣的文章
PHP问题 —— 丢失SESSION
查看>>
Java中Object类的equals()和hashCode()方法深入解析
查看>>
数据库
查看>>
Vue------第二天(计算属性、侦听器、绑定Class、绑定Style)
查看>>
dojo.mixin(混合进)、dojo.extend、dojo.declare
查看>>
Python 数据类型
查看>>
iOS--环信集成并修改头像和昵称(需要自己的服务器)
查看>>
PHP版微信权限验证配置,音频文件下载,FFmpeg转码,上传OSS和删除转存服务器本地文件...
查看>>
教程前言 - 回归宣言
查看>>
PHP 7.1是否支持操作符重载?
查看>>
Vue.js 中v-for和v-if一起使用,来判断select中的option为选中项
查看>>
Java中AES加密解密以及签名校验
查看>>
定义内部类 继承 AsyncTask 来实现异步网络请求
查看>>
VC中怎么读取.txt文件
查看>>
如何清理mac系统垃圾
查看>>
企业中最佳虚拟机软件应用程序—Parallels Deskto
查看>>
Nginx配置文件详细说明
查看>>
怎么用Navicat Premium图标编辑器创建表
查看>>
Spring配置文件(2)配置方式
查看>>
MariaDB/Mysql 批量插入 批量更新
查看>>