返回顶部
首页 > 资讯 > 前端开发 > JavaScript >详细聊聊Vue生命周期的那些事
  • 758
分享到

详细聊聊Vue生命周期的那些事

2024-04-02 19:04:59 758人浏览 泡泡鱼
摘要

目录前言一、Vue2中的生命周期实例的生命周期其它生命周期钩子二、vue3中的生命周期Optionsapi生命周期CompositionAPI生命周期两个新的Vue3生命周期函数最后

前言

如今学习Vue的人越来越多了,Vue框架React框架的学习也成为开发前端开发人员的必备技能,今天我们就来聊聊Vue中的生命周期函数,Vue中生命周期函数的参考价值很高,让我们来一起认识它吧~

一、Vue2中的生命周期

实例的生命周期

在介绍生命周期之前,我们需要知道在Vue中要渲染一块页面内容的时候,会有下面这几个过程:

  1. 解析语法生成 AST。
  2. 根据 AST 结果,完成 data 数据初始化。
  3. 根据 AST 结果和 data 数据绑定情况,生成虚拟 DOM。
  4. 将虚拟 DOM 生成真正的 DOM 插入到页面中,此时页面会被渲染。

当我们绑定的数据进行更新的时候,又会产生以下这些过程:

  1. 框架接收到数据变更的事件,根据数据生成新的虚拟 DOM 树。比较新旧两棵虚拟 DOM 树,得到差异。
  2. 把差异应用到真正的 DOM 树上,即根据差异来更新页面内容。

当我们清空页面内容时,还有:

  1. 注销实例,清空页面内容,移除绑定事件、监听器等。

Vue为实例提供的生命周期函数一共有8个:

  1. beforeCreate(): 初始化实例前,data、methods等不可获取——1之后,2之前
  2. created():实例化初始化完成,此时可获取data里数据和methods事件——2之后,3之前
  3. beforeMount():虚拟DOM创建完成,此时未挂载到页面中,vm.$el可获取未挂载模板——3之后,4之前
  4. mounted():数据绑定完成,真实DOM已挂载到页面,vm.$el可获取真实DOM——4之后
  5. beforeUpdate():数据更新,DOM Diff得到差异,未更新到页面——5之后,6之前
  6. updated():数据更新,页面也已更新——6之后
  7. beforeDestroy():实例销毁前——7之前
  8. destroyed():实例销毁完成——7之后

关于实例的生命周期,大家还可以参考官方的图例

其它生命周期钩子

其它的生命周期函数还有activated(), deactivated(), errorCaptured()

keep-alive独有的生命周期分别为activated和deactivated。

用keep-alive包裹的组件在切换时不会进行销毁,而是缓存在内存中并执行deactived钩子函数,命中缓存渲染后会执行activated钩子函数

errorCaptured()钩子当在子组件内捕获到错误时会调用这个钩子函数。

二、Vue3中的生命周期

Vue3中的生命周期在使用Options API和Composition API会有所不同。

Options API生命周期

  • beforeDestroy改为beforeUnmount
  • destroyed改为unmounted

尤大大为什么要把他改成这样,他的回复是这很大程度上是为了更好的命名约定,对应的中文正是卸载组件和前面的挂载组件契合不少。

  • 其它沿用Vue2生命周期

Composition API生命周期

在Composition API中使用钩子函数,我们只需要在钩子函数前面添加“on”,并在setup函数内部即可,它就会变成这样👇

我们只需要引入这些钩子函数就可以使用啦

Vue3的钩子函数如下:

  1. onBeforemount()
  2. onMounted()
  3. onBeforeUpdate()
  4. onUpdated()
  5. onBeforeUnmount()
  6. onUnmounted()
  7. onActivated()
  8. onDeactivated()
  9. onErrorCaptured()

如果你注意观察,你会发现两个生命周期函数消失了,beforeCreate()和created()不会出现在Composition API中,我们有setup()方法即可,setup()方法出现在beforeCreate()和created()之间。

两个新的Vue3生命周期函数

  • onRenderTracked():第一次在render函数中访问反应性依赖项时,将调用此函数,当我们想查看正在跟踪哪些依赖项时,钩子很有用,对调式很有作用。
  • onRenderTriggered():当触发新渲染时,将调用此选项,允许检查哪个依赖项触发了要重新渲染的组件。

最后

⚽这篇文章主要介绍了Vue中的生命周期函数,相信你一定有所收获~

到此这篇关于Vue生命周期的那些事的文章就介绍到这了,更多相关Vue生命周期内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 详细聊聊Vue生命周期的那些事

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

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

猜你喜欢
  • 详细聊聊Vue生命周期的那些事
    目录前言一、Vue2中的生命周期实例的生命周期其它生命周期钩子二、Vue3中的生命周期OptionsAPI生命周期CompositionAPI生命周期两个新的Vue3生命周期函数最后...
    99+
    2024-04-02
  • Angular学习之聊聊生命周期
    ngAfterContentInit当把外部的内容投影到内部组件,第一次调用 ngDoCheck 之后调用 ngAfterContentInit,而且只调用一次。// demo.component.ts ngAfterContentIni...
    99+
    2023-05-14
    生命周期 javascript Angular Angular.js
  • 详细聊一聊java中封装的那点事
    目录什么是封装封装拓展之包包的概念 什么是包访问权限什么是静态成员总结一下: 什么是封装 什么是封装呢?我们先来看一段代码 class Student { ...
    99+
    2024-04-02
  • 详细聊聊关于Mysql联合查询的那些事儿
    目录联合查询之union 1. 查询中国各省的ID以及省份名称 2. 湖南省所有地级市ID、名字 3. 用union将他们合并 联合查询之union a...
    99+
    2024-04-02
  • 聊聊vue生命周期钩子函数有哪些,分别什么时候触发
    目录vue生命周期钩子函数以下为详解版生命周期mounted和activated使用、踩坑 activatedmounted踩坑vue生命周期钩子函数 vue生命周期即为一...
    99+
    2024-04-02
  • Vue生命周期详解
    这篇博客将会从下面四个常见的应用诠释组件的生命周期,以及各个生命周期应该干什么事 单组件的生命周期父子组件的生命周期兄弟组件的生命周期宏mixin的生命周期 生命周期:Vue 实例从...
    99+
    2024-04-02
  • 详解vue生命周期
    目录为什么要理解生命周期什么是生命周期生命周期钩子函数created和mounted钩子的一些实战用法1.异步函数 2.Vue.nextTick对异步函数的结果进行操作 总结为什么要...
    99+
    2024-04-02
  • 详细聊聊Redis的过期策略
    保存过期时间 Redis可以为每个key设置过期时间,会将每个设置了过期时间的key放入一个独立的字典中。 typedef struct redisDb { int id; //i...
    99+
    2024-04-02
  • 一文聊聊Vue组件生命周期的三个阶段(创建、运行和销毁)
    总结生命周期:1)又称:生命周期回调函数、生命周期函数、生命周期钩子。2)含义:vue在关键时刻帮助我们调用一些特殊名称的函数。3)生命周期函数的名字不可更改,但函数的具体内容是程序员根据需求编写的。4)生命周期函数中的this指向是 vm...
    99+
    2023-05-14
    Vue 组件 生命周期
  • Vue组件与生命周期详细讲解
    目录写在前面生命周期图解总结写在前面 Vue.js的核心就是以简洁的模板语法将数据渲染进Dom系统。vue实例在渲染成html的时候往往要经过以下的步骤: 读取数据和方法,设置数据绑...
    99+
    2022-11-13
    Vue组件 Vue生命周期
  • 详细聊聊Vue中的options选项
    目录Vue中的options选项options的五类属性入门属性使用vue文件添加组件computed(计算属性)用途缓存示例:watch(监听)用途何为变化deep: true是干...
    99+
    2024-04-02
  • Vue.js的生命周期详细讲解
    本篇内容主要讲解“Vue.js的生命周期详细讲解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue.js的生命周期详细讲解”吧!用Vue框架,熟悉它的生命周期...
    99+
    2024-04-02
  • 详细聊聊Vue的混入和继承
    目录前言混入混入注意(重名情况)局部混入全局混入继承混入和继承的区别总结前言 Vue中的混入(mixin)是一个比较简单的知识点。熟悉CSS预处理语言比如less、sass的开发者对...
    99+
    2024-04-02
  • Vue生命周期区别详解
    生命周期分类 vue每个组件都是独立的,每个组件都有一个属于它的生命周期, 从一个组件创建、数据初始化、挂载、更新、销毁,这就是一个组件所谓的生命周期。 在组件中具体的方法有: ...
    99+
    2024-04-02
  • vue的生命周期钩子与父子组件的生命周期详解
    目录vue的生命周期钩子的介绍父子组件的生命周期加载渲染过程父组件更新过程子组件更新过程父子组件更新过程销毁过程代码示例created和mounted的区别vue的生命周期钩子的介绍...
    99+
    2022-11-13
    vue 生命周期 vue 父子组件生命周期
  • vue生命周期包括哪些
    vue生命周期包括:1.创建前,钩子函数为beforeCreate;2.创建后,钩子函数为created;3.载入前,钩子函数为beforemount;4.载入后,钩子函数为mounted;5.更新前,钩子函数为beforeUpdate;6...
    99+
    2024-04-02
  • Android Activity的生命周期详细介绍
    Android Activity的生命周期详细介绍 生命周期描述的是一个类从创建(new出来)到死亡(垃圾回收)的过程中会执行的方法。在这个过程中,会针对不同的生命阶段调用不同...
    99+
    2022-06-06
    activity Android
  • Flutter生命周期超详细讲解
    目录一、组件生命周期1、StatelessWidget2、StatefulWidget2.1、初始化阶段2.2、状态变化阶段2.3、销毁阶段二、App生命周期一、组件生命周期 flu...
    99+
    2023-01-29
    Flutter生命周期研究 Flutter生命周期方法
  • ReactState与生命周期详细介绍
    目录一、State1.1 类组件中的State1.2 函数组件中的State二、React生命周期2.1 挂载2.2 更新2.3 卸载2.4 函数式组件useEffect三、总结一、...
    99+
    2024-04-02
  • 详细聊聊Vue中的MVVM模式原理
    目录1. MVVM模式2. Vue响应式3. Vue监听对象3.1 监听普通对象3.2 监听复杂对象(深度监听)4. Vue监听数组5. 使用 Object.defineProper...
    99+
    2023-03-03
    vue.js mvvm vue.js教程 vue mvvm模式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作