“每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等” ,在不同的生命周期内会经历不同的钩子函数(生命周期函数),这就提供了将我们自己的代码写入的机会。如果将生命周期比作人的话,生命周期就是一个人的一生,生命钩子函数就相当于人的不同年龄段(幼年、青年、中年、老年),人在不同的年龄段做的事就相当于生命周期钩子函数所执行的任务。官方将vue实例的生命周期分为:beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy、destroyed几个生命周期函数(钩子函数)。

vue生命周期图如下:

1、beforeCreate:

官方解释:“在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用”。此时data和methods还未初始化,也就是还不能进行data和methods的操作,此时访问data和调用methods代码和结果如下:

源码:

  1. <template>
  2. <div class="hello">
  3. {{originData}}
  4. </div>
  5. </template>
  6.  
  7. <script>
  8. export default {
  9. name: 'HelloWorld',
  10. data(){
  11. return{
  12. originData:'hello Vue'
  13. }
  14. },
  15. beforeCreate(){
  16. console.log('beforeCreate----------');
  17. console.log(this.originData);
  18. this.methodone();
  19.  
  20. },
  21. created(){
  22. alert('created');
  23. },
  24. methods:{
  25. methodone(){
  26. console.log('这是vue实例的方法');
  27. }
  28. }
  29. }
  30. </script>
  31. <style scoped>
  32.  
  33. </style>

结果:

2、created:

官方解释:“在实例创建完成后被立即调用。在这一步,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。”此时可以访问data中的数据也可以调用methods中的方法,代码     和执行结果如下:

  1. <template>
  2. <div class="hello">
  3. {{originData}}
  4. </div>
  5. </template>
  6.  
  7. <script>
  8. export default {
  9. name: 'HelloWorld',
  10. data(){
  11. return{
  12. originData:'hello Vue'
  13. }
  14. },
  15. beforeCreate(){
  16. console.log('beforeCreate----------');
  17. },
  18. created(){
  19. //可以访问data中的originData和调用methods中方法methodone了也可以修改data中的数据了。这里一般可以写一些与dom结构无关的初始化数据。
  20. console.log('created-----------');
  21. console.log(this.originData);
  22. this.originData='更新的data数据'
  23. this.methodone();
  24. console.log(this.originData);
  25. },
  26. beforeMount(){
  27. alert('beforeMount');
  28. console.log('beforeMount----------');
  29. },
  30. methods:{
  31. methodone(){
  32. console.log('这是vue实例的方法');
  33. }
  34. }
  35. }
  36. </script>
  37. <style scoped>
  38.  
  39. </style>

3、beforeMount:

官方解释:“在挂载开始之前被调用:相关的 render 函数首次被调用”,此时模板已经编译好,准备就绪,还未挂载到dom上。

4、mounted:

官方解释:“el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。如果 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。”,此时模板结构已经挂载到了dom上,可以通过原生js操作dom了,第三方插件需要获取dom结构的可以在此钩子函数中进行操作。到目前为止整个Vue实例对象已经初始      化完毕了,此时组件已经脱离创建阶段,进入运行阶段。

  1. <template>
  2. <div class="hello">
  3. <p id="box">{{originData}}</p>
  4. <button @click="btn">修改数据</button>
  5. </div>
  6. </template>
  7.  
  8. <script>
  9. export default {
  10. name: 'HelloWorld',
  11. data(){
  12. return{
  13. originData:'hello Vue'
  14. }
  15. },
  16. beforeCreate(){
  17. //1、初始化数据
  18. console.log('beforeCreate----------');
  19. },
  20. created(){
  21. //2、可以访问data中的originData和调用methods中方法methodone了也可以修改data中的数据了。这里一般可以写一些与dom结构无关的初始化数据。
  22. console.log('created-----------');
  23. console.log(this.originData);
  24. },
  25. beforeMount(){
  26. //3、准备就绪,还未更新dom结构
  27. // console.log(document.getElementsByClassName('hello')[0].innerHTML);
  28. console.log('beforeMount----------');
  29.  
  30. },
  31. mounted(){
  32. //4、模板已经挂载到了dom结构上,可以进行dom操作了
  33. console.log('mounted----------');
  34. console.log(document.getElementById('box').innerHTML);//hello Vue,能获得dom的内容
  35. alert('beforeMount');
  36. },
  37. methods:{
  38. methodone(){
  39. console.log('这是vue实例的方法');
  40. },
  41. btn(){
  42. this.originData='修改的数据'
  43. }
  44. }
  45. }
  46. </script>
  47. <style scoped>
  48.  
  49. </style>

5、beforeUpdate:

官方解释:“数据更新时调用,发生在虚拟 DOM 打补丁之前。这里适合在更新之前访问现有的 DOM,比如手动移除已添加的事件监听器 ”。当data中的数据发生变化,首先调用此方法,此方法是未更新dom结构之前。

代码:

功能:点击 “修改数据”按钮,修改originData的数据为"修改的数据",此时dom结构为发生变化。

  1. export default {
  2. name: 'HelloWorld',
  3. data(){
  4. return{
  5. originData:'hello Vue'
  6. }
  7. },
  8. beforeCreate(){
  9. //1、初始化数据
  10. console.log('beforeCreate----------');
  11. },
  12. created(){
  13. //2、可以访问data中的originData和调用methods中方法methodone了也可以修改data中的数据了。这里一般可以写一些与dom结构无关的初始化数据。
  14. console.log('created-----------');
  15. console.log(this.originData);
  16. },
  17. beforeMount(){
  18. //3、准备就绪,还未更新dom结构
  19. // console.log(document.getElementsByClassName('hello')[0].innerHTML);
  20. console.log('beforeMount----------');
  21.  
  22. },
  23. mounted(){
  24. //4、模板已经挂载到了dom结构上,可以进行dom操作了
  25. console.log('mounted----------');
  26. console.log(document.getElementById('box').innerHTML);//hello Vue,能获得dom的内容
  27. // alert('mounted');
  28. },
  29. beforeUpdate(){
  30. //5、当data中的数据发生变化,首先调用此方法,此方法是未更新dom结构之前
  31. alert('beforeUpdate');
  32. },
  33. methods:{
  34. methodone(){
  35. console.log('这是vue实例的方法');
  36. },
  37. btn(){
  38. this.originData='修改的数据'
  39. }
  40. }
  41. }

6、updated:

官方解释:“当这个钩子被调用时,组件 DOM 已经更新,所以你现在可以执行依赖于 DOM 的操作。然而在大多数情况下,你应该避免在此期间更改状态。”,执行到此处说明数据已经更新到了dom结构上。

操作:点击上一步的“确定”按钮,程序执行到了updated钩子函数中,此时修改的数据已经更新到了dom结构上。

  1. export default {
  2. name: 'HelloWorld',
  3. data(){
  4. return{
  5. originData:'hello Vue'
  6. }
  7. },
  8. beforeCreate(){
  9. //1、初始化数据
  10. console.log('beforeCreate----------');
  11. },
  12. created(){
  13. //2、可以访问data中的originData和调用methods中方法methodone了也可以修改data中的数据了。这里一般可以写一些与dom结构无关的初始化数据。
  14. console.log('created-----------');
  15. console.log(this.originData);
  16. },
  17. beforeMount(){
  18. //3、准备就绪,还未更新dom结构
  19. // console.log(document.getElementsByClassName('hello')[0].innerHTML);
  20. console.log('beforeMount----------');
  21.  
  22. },
  23. mounted(){
  24. //4、模板已经挂载到了dom结构上,可以进行dom操作了
  25. console.log('mounted----------');
  26. console.log(document.getElementById('box').innerHTML);//hello Vue,能获得dom的内容
  27. // alert('mounted');
  28. },
  29. beforeUpdate(){
  30. //5、当data中的数据发生变化,首先调用此方法,此方法是未更新dom结构之前
  31. alert('beforeUpdate');
  32. },
  33. updated(){
  34. //6、此时数据已经更新到了dom结构上
  35. console.log('数据更新成功');
  36. },
  37. methods:{
  38. methodone(){
  39. console.log('这是vue实例的方法');
  40. },
  41. btn(){
  42. this.originData='修改的数据'
  43. }
  44. }
  45. }

7、beforeDestroy:

官方解释“ 实例销毁之前调用。在这一步,实例仍然完全可用。” 一般在此钩子函数中移除监听、清除定时器。

8、destroyed:

官方解释“ Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。” 此钩子函数对于我们没什么用处。

浅析vue实例的生命周期(生命周期钩子)的更多相关文章

  1. Vue 实例详解与生命周期

    Vue 实例详解与生命周期 Vue 的实例是 Vue 框架的入口,其实也就是前端的 ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进 ...

  2. 05-Vue入门系列之Vue实例详解与生命周期

    Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进行对整个Vue实例生成.编译.挂着. ...

  3. Vue入门系列(五)Vue实例详解与生命周期

    Vue官网: https://cn.vuejs.org/v2/guide/forms.html#基础用法 [入门系列] (一)  http://www.cnblogs.com/gdsblog/p/78 ...

  4. Vue实例详解与生命周期

    http://www.jianshu.com/p/b5858f1e6e76 Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己 ...

  5. Vue.js-07:第七章 - Vue 实例的生命周期

    一.前言  在之前的 Vue 学习中,我们在使用 Vue 时,都会创建一个 Vue 的实例,而每个 Vue 实例在被创建时都要经过一系列的初始化过程.例如,需要设置数据监听.编译模板.将实例挂载到 D ...

  6. vue实例生命周期详解

    每个 Vue 实例在被创建之前都要经过一系列的初始化过程. 例如,实例需要配置数据观测(data observer).编译模版.挂载实例到 DOM ,然后在数据变化时更新 DOM . 在这个过程中,实 ...

  7. Vue – 基础学习(1):对生命周期和钩子函的理解

    一.简介 先贴一下官网对生命周期/钩子函数的说明(先贴为敬):所有的生命周期钩子自动绑定 this 上下文到实例中,因此你可以访问数据,对属性和方法进行运算.这意味着你不能使用箭头函数来定义一个生命周 ...

  8. vue实例生命周期

    实例生命周期 var vm = new Vue({ data: { a: 1 }, created: function () { // `this` 指向 vm 实例 console.log('a i ...

  9. Vue 实例中的生命周期钩子

    Vue 框架的入口就是 Vue 实例,其实就是框架中的 view model ,它包含页面中的业务处理逻辑.数据模型等,它的生命周期中有多个事件钩子,让我们在控制整个Vue实例的过程时更容易形成好的逻 ...

随机推荐

  1. php算法题2

    一群猴子排成一圈,按1,2,…,n依次编号.然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去…,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大 ...

  2. 我的WafBypass之道(Misc篇)

    先知技术社区独家发表本文,如需要转载,请先联系先知技术社区授权:未经授权请勿转载.先知技术社区投稿邮箱:Aliyun_xianzhi#service.alibaba.com: Author:Tr3je ...

  3. 22.1 、react生命周期(一)

    在每个react组件中都有以下几个生命周期方法~我们需要在不同阶段进行讨论 组件生命周期概述 1.初始化 在组件初始化阶段会执行 constructor static getDerivedStateF ...

  4. 手把手JDK环境变量配置

    分为下载,配置,验证三个步骤解释如何进行JDK环境变量配置. 步骤一: 首先查看配置成功后的效果: tip:点击win——>运行(或者使用win+r,或者shift+鼠标右键打开powershe ...

  5. CTextUI 文本控件 显示数字方法

    得将数字变成字符串才行 m_ptxtCurrentcharUI->SetText(util::int32ToCString(txtLength)); 或 String.valueOf(x) 或 ...

  6. CSS斜切角

    问题 斜切角在Web设计和印刷中是相当受欢迎的样式.它通常是在一个或多个元素的角落切一个45°的角(也就是所谓的斜切角).特别是最近,扁平化设计的势头压过了拟真设计,也使这种效果更加流行.当斜切角只存 ...

  7. Linux基础:用tcpdump抓包(转)

    https://segmentfault.com/a/1190000012593192 https://segmentfault.com/a/1190000009691705

  8. ZOJ 4060 - Flippy Sequence - [思维题][2018 ACM-ICPC Asia Qingdao Regional Problem C]

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4060 题意: 给出两个 $0,1$ 字符串 $S,T$,现在你有 ...

  9. 关于break,return,和coutiune

    public boolean searchStudent(String name,int start,int end) { if(students==null) { return false; } f ...

  10. python-----编写接口,使用postman与soapiu与jemeter访问调用

    实例:自己写一个注册接口 输入用户名.密码.验证码,当满足注册将密码进行md5加密. 场景 接口返回参数 提示 用户名存在 2000 exit 用户已存在 密码与验证码不相等 3000 wrong 密 ...