写在前面:进行一些项目实践的时候,总会涉及到关于生命周期钩子或多或少的使用。因此觉得有必要单独梳理一下相关的知识点,如有理解错误的地方恳请告知修改。

总体感知

首先贴一张Vue文档给出的生命周期图示,并添加了一些注释

Vue2.0的生命周期钩子一共有10个,同样结合官方文档作出了下表

生命周期钩子 详细
beforeCreate 在实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用。
created 实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算, watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。
beforeMount 在挂载开始之前被调用:相关的 render 函数首次被调用。
mounted el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。如果 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。
beforeUpdate 数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。你可以在这个钩子中进一步地更改状态,这不会触发附加的重渲染过程。
updated 由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。当这个钩子被调用时,组件 DOM 已经更新,所以你现在可以执行依赖于 DOM 的操作。
activated keep-alive 组件激活时调用。
deactivated keep-alive 组件停用时调用。
beforeDestroy 实例销毁之前调用。在这一步,实例仍然完全可用。
destroyed Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

(除了beforeCreate和created钩子之外,其他钩子均在服务器端渲染期间不被调用。)

实际操作

我们来可视化的观察一下生命周期钩子函数执行时状态变化的情况

测试过程基于以下代码执行,引入vue.js后可直接执行

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><script src="./vue.js"></script>
</head>
<body>
<div id="app"><p>{{message}}</p><keep-alive><my-components msg="hello" v-if="show"></my-components></keep-alive>
</div>
</body>
<script>var child = {template: '<div>from child: {{msg}}</div>',props: ['msg'],data: function () {return {childMsg: 'child'};},deactivated: function () {console.log('component deactivated!');},activated: function () {console.log('component activated');}};var app = new Vue({el: '#app',data: function () {return {message: 'father',show: true};},beforeCreate: function () {console.group('beforeCreate 创建前状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(state);},created: function () {console.group('created 创建完毕状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(state);},beforeMount: function () {console.group('beforeMount 挂载前状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(this.$el);console.log(state);},mounted: function () {console.group('mounted 挂载结束状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(this.$el);console.log(state);// this.message = 'change';},beforeUpdate: function () {console.group('beforeUpdate 更新前状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(this.$el);console.log(state);// this.message = 'change2';},updated: function () {console.group('updated 更新完成状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(this.$el);console.log(state);},beforeDestroy: function () {console.group('beforeDestroy 销毁前状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(this.$el);console.log(state);},destroyed: function () {console.group('destroyed 销毁完成状态===============》');var state = {'el': this.$el,'data': this.$data,'message': this.message}console.log(this.$el);console.log(state);},components: {'my-components': child}});
</script>
</html>

首先来梳理一下结构:
1.我们创建了一个Vue根实例命名为app,将其挂载到页面id为app的dom元素上。
2.局部注册的一个组件child并在根实例中将其注册使其可以在根实例的作用域中使用。
3.将子组件用<keep-alive> 包裹,为接下来的测试作准备。
在谷歌浏览器打开开发者工具,开始测试!

create 和 mounted 相关

测试效果图如下:

根据测试结果,可以看出

1.beforeCreate执行时:data和el均未初始化,值为undefined

2.created执行时:Vue 实例观察的数据对象data已经配置好,已经可以得到app.message的值,但Vue 实例使用的根 DOM 元素el还未初始化
3.beforeMount执行时:data和el均已经初始化,但从{{message}}等现象可以看出此时el并没有渲染进数据,el的值为“虚拟”的元素节点
4.mounted执行时:此时el已经渲染完成并挂载到实例上

activated 和 destroyed相关

  在前面的测试图中,我们发现了activated周期钩子已经被触发,这是因为子组件my-components被<keep-alive> 包裹,随el的挂载触发。
  现在我们将此组件停用进行测试:由于子组件具有一个v-if指令v-if="show",因此我们可以通过将show的值置为false将其销毁。
  控制台输入 app.show = false;测试结果如下:

由于在这里我们修改了data的值,所以会触发beforeUpdate和updated钩子,这里先不讨论这一组钩子,我们看到deactivated钩子已经触发,表示<keep-alive>已经停用,符合预期结果。

  

现在我们对Vue实例进行销毁,调用app.$destroy()方法即可将其销毁,控制台测试如下:

我们发现实例依然存在,但是此时变化已经发生在了其他地方,根据官方文档描述:Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

继续测试,现在修改 data中的数据查看结果,如下:

这里我们将data中的message属性改成了'world',发现dom并没有进行相应的响应,这证实了之前的说法。同样,如果你在子组件也加入destroyed钩子,发现该钩子也会被触发,这也证明了子实例也会被一起销毁。这里的销毁并不指代'抹去',而是表示'解绑'。

updated相关

beforeUpdate和updated是最后一对周期钩子了。
为了能看出测试的具体效果,我们需要在原来的代码上添加两行代码:

在c钩子和updated钩子中分别加上

console.log('beforeUpdate == ' + document.getElementsByTagName('p')[0].innerHTML);

控制台输入app.message = 'abc';效果如下:

我们发现beforeUpdate和updated触发时,el中的数据都已经渲染完成,但根据beforeUpdate == father而updated == abc可知,只有updated钩子被调用时候,组件dom才被更新。

一些应用的想法

  1. 在created钩子中可以对data数据进行操作,这个时候可以进行ajax请求将返回的数据赋给data

  2. 在mounted钩子对挂载的dom进行操作

  3. 在使用vue-router时有时需要使用<keep-alive></keep-alive>来缓存组件状态,这个时候created钩子就不会被重复调用了,如果我们的子组件需要在每次加载的时候进行某些操作,可以使用activated钩子触发。

结尾

到这里已经总结完成了,感觉只有理解的生命周期钩子的使用,才能更好配合其他方法事件使用。如果您发现错误的地方,请告诉我及时修改,谢谢!

关于Vue.js2.0生命周期的研究与理解相关推荐

  1. 耗时近一个月,终于录完了VUE.JS2.0前端视频教程!

    这次课录制的比较辛苦,圣诞节时原本已经快录制完成了,偶然的一次,播放了一下,感觉不满意,好几篇推倒重来,所以今天才结束. vue.js2.0是Vue.JS的最新版本,视频教程还不多,如果你看到了,学到 ...

  2. vue组件的生命周期和执行过程

    Vue所有的生命周期钩子自动绑定在this上下文到实例中,因此你可以访问数据,对属性和方法进行运算.这意味着你不能使用箭头函数来定义一个生命周期方法.这是因为箭头函数绑定了父上下文,因此this与你期 ...

  3. Vue父子组件生命周期

    Vue父子组件生命周期 Vue实例需要经过创建.初始化数据.编译模板.挂载DOM.渲染.更新.渲染.卸载等一系列过程,这个过程就是Vue的生命周期,Vue中提供的钩子函数有beforeCreate.c ...

  4. python 全栈开发,Day91(Vue实例的生命周期,组件间通信之中央事件总线bus,Vue Router,vue-cli 工具)...

    昨日内容回顾 0. 组件注意事项!!!data属性必须是一个函数!1. 注册全局组件Vue.component('组件名',{template: ``})var app = new Vue({el: ...

  5. Vue实例的生命周期详解,从创建到销毁全过程

    文章目录 前言 初识new Vue Vue实例从创建到销毁 1.创建之前-beforeCreate() 2.创建之后-created() 3.实例对象和文档挂载之前-beforeMount() 4.实 ...

  6. Vue实例的生命周期

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

  7. Vue.js2.0开发环境搭建(三)

    转载自  Vue.js2.0从入门到放弃---入门实例(三) 今天就来简单说一下vue-resource,这是vue的一个与服务器端通信的HTTP插件,用来从服务器端请求数据.话不多说,直接上干货吧. ...

  8. Vue.js2.0开发环境搭建(一)

    转载自  Vue.js2.0从入门到放弃---入门实例(一) 最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题 ...

  9. vue父子组件生命周期顺序_vue父子组件生命周期执行顺序

    Parent -- Child1 -- Child2 装载 parent beforeCreate parent created parent beforeMount child1 beforeCre ...

最新文章

  1. 人为何会发烧,超过42°C会怎样?
  2. CAS单点登录3--服务端登录页个性化
  3. vi-vim常用命令
  4. 2021年常用中药相关数据库介绍
  5. 使用绘图类库flotr2来绘制HTML5的图形和图表
  6. linux之nautilus .命令浏览当前文件目录
  7. 从Java 11中删除的API
  8. Java中的42行代码中的URL缩短服务— Java(?!)Spring Boot + Redis
  9. php sqlite视图,SQLite 视图
  10. hadoop yarn 集群配置
  11. 【每日算法Day 105】打家劫舍第二弹:看好你的电瓶车!
  12. bash脚本比较运算符和if else和test命令
  13. HTML5期末大作业:动漫网站设计——千与千寻(10页) 含设计报告 HTML+CSS+JavaScript 学生动漫网页设计模板下载 海贼王大学生HTML网页制作作品
  14. 【物联网】NB-IoT和LoRa技术简介
  15. 14.Java实现UDP通信
  16. java是如何调用native方法?hotspot源码分析必会技能
  17. 微波暗室——天线方向图测试
  18. 计算机毕业论文提纲如何写,计算机毕业论文提纲怎么写
  19. flink本地运行及访问webui
  20. 吐血整理 | 肝翻 Linux 同步管理所有知识点

热门文章

  1. 光纤通信及周边产品知识汇总
  2. Ubuntu系统安装stardict(星际译王)词典
  3. JAVA---AWT 图形绘制
  4. linux下安装redmine1.2.1全记录
  5. 在WEBSERVICE学习中遇到的问题
  6. webpy + nginx + fastcgi 构建python应用
  7. python模块导入
  8. Spring AOP源码分析(六)Spring AOP配置的背后
  9. Java基础系列:(2)关于枚举的简单总结
  10. centOS 7 安装man中文版手册