返回顶部
首页 > 资讯 > 精选 >Vue八大生命周期钩子函数源码分析
  • 424
分享到

Vue八大生命周期钩子函数源码分析

2023-07-05 17:07:14 424人浏览 八月长安
摘要

本篇内容主要讲解“Vue八大生命周期钩子函数源码分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue八大生命周期钩子函数源码分析”吧!一.速识概念:我们把一个对象从生成(new)到被销毁(d

本篇内容主要讲解“Vue八大生命周期钩子函数源码分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue八大生命周期钩子函数源码分析”吧!

一.速识概念:

我们把一个对象从生成(new)到被销毁(destory)的过程,称为生命周期。而生命周期函数,就是在某个时刻会自动执行的函数。
按照官方的原话,就是每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会。
简单来说就是每个Vue实例在被创建时都要经过一系列的初始化过程:创建实例,装载模板,渲染模板等。Vue为生命周期中的每个状态都设置了钩子函数(监听函数) 。每当Vue实例处于不同的生命周期时,对应的函数就会被触发调用。

二.八大生命周期钩子函数:

函数调用时间
beforeCreatevue实例初始化之前调用
createdvue实例初始化之后调用
beforeMount挂载到DOM树之前调用
mounted挂载到DOM树之后调用
beforeUpdate数据更新之前调用
updated数据更新之后调用
beforeDestroyvue实例销毁之前调用
destroyedvue实例销毁之后调用

下面是官方文档里的生命周期图,英语好的同学可以看看:

Vue八大生命周期钩子函数源码分析

三.结合代码了解:

先看案例基本代码如下,后面通过如下代码步骤演示一个对象从生成到被销毁的过程各阶段执行的生命周期函数。注意show函数的作用。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta Http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title>    <script src="https://unpkg.com/vue/dist/vue.js"></script></head><body>    <div id="app">        {{infORMation}}    </div>    <script type="text/javascript">       //创建vue实例       var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            }       })       // 各个生命周期函数通过调用下面这个函数了解其所处的生命阶段       function show(inf,obj){          console.log(inf);          console.log("------------------------------------------");          console.log('获取vue实例data里的数据:');          console.log(obj.information);          console.log("------------------------------------------");          console.log('挂载的对象,就是DOM:');          console.log(obj.$el);          console.log("------------------------------------------");          console.log('页面上已经挂载的DOM:');          console.log(document.getElementById('app').innerHTML);       }    </script>

1. beforeCreate:

这个阶段vue实例刚刚在内存中创建,此时data和methods这些都没初始化好。
在案例中添加beforeCreate钩子函数:

 var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },           beforeCreate: function(){             // 传入该阶段简介与this,this就是该阶段的vue实例                  show('vue实例初始化之前',this);           }       })

看运行结果:

Vue八大生命周期钩子函数源码分析

可以看到,此时vue实例刚刚在内存中创建,其它什么都undefined。

2.created:

这个阶段vue实例在内存中已经创建好了,data和methods也能够获取到了,但是模板还没编译。
在案例中添加created钩子函数:

 var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },           created: function(){                  show('vue实例初始化之后',this);           }       })

看结果:

Vue八大生命周期钩子函数源码分析

看到没,已经知道data里的数据了。其它的话都没。

3.beforeMount:

这个阶段完成了模板的编译,但是还没挂载到页面上。
在案例中添加钩子函数:

 var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },           beforeMount: function(){             show('挂载之前',this);           }       })

看结果:

Vue八大生命周期钩子函数源码分析

看到没,要挂载的对象都编译好了,但是页面的DOM树还没挂上去,这个阶段页面还没能显示出来。

4.mounted:

这个阶段,模板编译好了,也挂载到页面中了,页面也可以显示了。
在案例中添加钩子函数:

  var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },           mounted: function(){            show('挂载之后',this);           }       })

看结果:

Vue八大生命周期钩子函数源码分析

5.beforeUpdate:

转态更新之前执行此函数,此时data中数据的状态值已经更新为最新的,但是页面上显示的数据还是最原始的,还没有重新开始渲染DOM树。

先改变data里数据:

vm.information = '南极光之夜';

在案例中添加钩子函数:

 var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },          beforeUpdate: function(){            show('更新之前',this);           }       })

看结果:

Vue八大生命周期钩子函数源码分析

看到没,vue实例里的数据已经变成了南极光之夜。但是此阶段页面DOM节点上显示的还是初始的数据北极光之夜。

6.updated:

这个阶段是转态更新完成后执行此函数,此时data中数据的状态值是最新的,而且页面上显示的数据也是最新的,DOM节点已经被重新渲染了。

在案例中添加钩子函数:

  var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },          updated: function(){            show('更新之后',this);           }       })

看运行结果:

Vue八大生命周期钩子函数源码分析

更新了,全都更新了~

7.beforeDestroy:

beforeDestroy阶段处于vue实例被销毁之前,当然,这个阶段vue实例还能用。

销毁Vue实例:

vm.$destroy();

在案例中添加钩子函数:

 var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },          beforeDestroy: function() {            show('销毁之前',this);          }       })

看效果:

Vue八大生命周期钩子函数源码分析

8.destroyed:

这个阶段在vue实例销毁后调用,此时所有实例指示的所有东西都会解除绑定,事件监听器也都移除,子实例也被销毁。

在案例中添加钩子函数:

var vm = new Vue({           el: '#app',           data: {               information: '北极光之夜。'            },          destroyed: function() {            show('销毁之后',this);          }       })

看结果:

Vue八大生命周期钩子函数源码分析

到此,相信大家对“Vue八大生命周期钩子函数源码分析”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Vue八大生命周期钩子函数源码分析

本文链接: https://lsjlt.com/news/354033.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue八大生命周期钩子函数源码分析
    本篇内容主要讲解“Vue八大生命周期钩子函数源码分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue八大生命周期钩子函数源码分析”吧!一.速识概念:我们把一个对象从生成(new)到被销毁(d...
    99+
    2023-07-05
  • Vue生命周期中的八个钩子函数相机
    目录1、beforeCreate和created函数2、beforeMount和mounted函数3、beforeUpdate和updated函数4、beforeDestroy和de...
    99+
    2024-04-02
  • vue中的生命周期及钩子函数
    目录1.什么是生命周期2.vue 的生命周期3.生命周期钩子函数1.什么是生命周期 Vue 实例有一个完整的生命周期,也就是从开始创建、初始化数据、编译模板、挂载 Dom、渲染 &r...
    99+
    2024-04-02
  • vue生命周期钩子函数是什么
    本篇内容主要讲解“vue生命周期钩子函数是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue生命周期钩子函数是什么”吧!vue生命周期钩子函数vue生命周期即为一个组件从出生到死亡的一个完...
    99+
    2023-06-30
  • Vue 2.0中生命周期与钩子函数的示例分析
    小编给大家分享一下Vue 2.0中生命周期与钩子函数的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!vue生命周期简介咱...
    99+
    2024-04-02
  • vue的生命周期钩子函数有哪些
    vue的生命周期钩子函数有:1.beforeCreate,对应阶段为创建前;2.created,对应阶段为创建后;3.beforemount,对应阶段为载入前;4.mounted,对应阶段为载入后;5.beforeUpdate,对应阶段为更...
    99+
    2024-04-02
  • Vue生命周期中的八个钩子函数相机是怎样的
    Vue生命周期中的八个钩子函数相机是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、beforeCreate和created函数beforeCreate和created...
    99+
    2023-06-22
  • vue的生命周期钩子函数怎么应用
    本篇内容介绍了“vue的生命周期钩子函数怎么应用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在vue中,生命周期钩子函数指的是当生命周期经...
    99+
    2023-06-29
  • 如何理解Vue生命周期和钩子函数
    这期内容当中小编将会给大家带来有关如何理解Vue生命周期和钩子函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1. vue生命周期一组件从 创建 到 销毁 的整个过程就是生命周期Vue 实例从创建到销毁...
    99+
    2023-06-25
  • Vue生命周期介绍和钩子函数详解
    目录Vue生命周期介绍和钩子函数 VUE生命周期钩子 Vue生命周期简介 create 和 mounted 相关 update 相关 destroy 相关 总结 Vue生命周期介绍和...
    99+
    2024-04-02
  • Vue3生命周期钩子函数详解
    本文实例为大家分享了Vue3生命周期钩子函数的具体代码,供大家参考,具体内容如下 一、Vue3生命周期钩子 setup() : 开始创建组件之前,在 beforeCreate 和 c...
    99+
    2024-04-02
  • angular4生命周期钩子的示例分析
    这篇文章主要介绍angular4生命周期钩子的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!理解Angular提供了生命周期钩子,把这些关键生命时刻暴露出来,赋予我们在它们发...
    99+
    2024-04-02
  • vue中的生命周期和钩子函数是什么
    这篇文章主要讲解了“vue中的生命周期和钩子函数是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中的生命周期和钩子函数是什么”吧!1.什么是生命周期Vue 实例有一个完整的生命周期...
    99+
    2023-06-21
  • vue的生命周期钩子与父子组件的生命周期详解
    目录vue的生命周期钩子的介绍父子组件的生命周期加载渲染过程父组件更新过程子组件更新过程父子组件更新过程销毁过程代码示例created和mounted的区别vue的生命周期钩子的介绍...
    99+
    2022-11-13
    vue 生命周期 vue 父子组件生命周期
  • Vue生命周期钩子如何运行
    这篇文章主要讲解了“Vue生命周期钩子如何运行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue生命周期钩子如何运行”吧!生命周期钩子Vue 在生命周期钩子方面有两种范式。一种是 Vue3...
    99+
    2023-07-02
  • vue parseHTML函数源码分析start钩子函数
    这篇文章主要讲解了“vue parseHTML函数源码分析start钩子函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue parseHTML函数源码分析start...
    99+
    2023-07-02
  • rust生命周期源码分析
    本文小编为大家详细介绍“rust生命周期源码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“rust生命周期源码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。rust生命周期生命周期是rust中用来规定引...
    99+
    2023-07-05
  • Vue父子组件生命周期的执行顺序及钩子函数
    这篇文章主要介绍“Vue父子组件生命周期的执行顺序及钩子函数”,在日常操作中,相信很多人在Vue父子组件生命周期的执行顺序及钩子函数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2024-04-02
  • 带你一文了解Vue生命周期钩子
    目录前言生命周期钩子选项式API(Options API)生命周期流程图运行生命周期挂钩beforeCreate()created()beforeMount()mounted()be...
    99+
    2024-04-02
  • Angular组件中生命周期钩子的示例分析
    这篇文章主要介绍了Angular组件中生命周期钩子的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Angular 组件生命周期钩子其中,红色标记的生命周期钩子只调用一...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作