框架篇-面试题6-说一下Vue2与Vue3的钩子函数

news2025/1/11 2:00:36

e06aa4678b881528fd9c0992b403659d.png

Vue钩子函数是在Vue实例从创建到销毁的过程中自动执行的函数(在特定的阶段,能够自动自执行的函数)

钩子函数用来描述一个组件从引入(创建)到退出(销毁)的全过程中的某个过程

Vue2生命周期钩子函数

整个过程称为生命周期Vue钩子函数按照组件生命周期的过程分为挂载阶段,更新阶段和销毁阶段

  1. beforeCreate():在new一个Vue实例后,只有一些默认的生命周期钩子和默认事件,其他的东西都还没创建,在此生命周期执行的时候,datamethods中的数据都没有初始化

  2. created():在示例创建完成之后,数据已经准备好,但是挂载DOM节点还没有开始,此时无法访问DOM节点

  3. beforeMount():在挂载开始之前被调用,render函数首次被调用,在此时,模板编译成了render函数,但是还没有渲染成真实的DOM节点

  4. mounted():在挂载完成后被调用,此时DOM节点已经全部渲染完毕,可以在这个钩子函数中操作DOM节点,例如获取元素的大小和位置等

  5. beforeUpdate():在数据更新之前被调用,可以在此时对更新前的数据进行操作,但此时还无法访问到更新后的数据

  6. updated():在数据更新后被调用,DOM已经被重新渲染,可以在此时对DOM进行操作,但是需要注意避免无限循环的情况

  7. beforeDestory():在实例销毁之前被调用,可以在此时进行一些清理工作,例如:清除定时器或取消事件监听等

  8. destroyed():在实例销毁之后被调用,此时实例中的所有东西都已经被销毁,无法在访问到实例中的数据和方法

在父子组件中,钩子函数的执行顺序如下所示

  • 挂载阶段: 父beforeCreate > 父created > 子beforeCreate > 子created > 子beforeMount > 子mounted > 父mounted

  • 更新阶段:父beforeUpdate > 子beforeUpdate > 子updated >父updated

  • 销毁阶段: 父beforeDestory > 子beforeDestory > 子destoryed > 父destoryed

总之,Vue钩子函数是,在特定阶段,能够自动执行的函数,例如:在数据更新后对DOM进行操作或在实例销毁前进行一些清理工作

Vue3生命周期钩子函数

Vue3的生命周期钩子函数和Vue2的生命周期选项是很相似的,但是Vue3中的生命周期钩子函数被命名为“钩子”,并且使用了Composition API的方式来实现。以下是Vue3的钩子函数:

setup():在组件创建之前执行,相当于Vue2中的beforeCreatecreated钩子函数,用于创建组件的datamethod,它是在beforeCreate之前就执行了的

  • onBeforeMount():在组件挂载到节点上之前执行的函数,相当于Vue2中的beforeMount钩子函数。

  • onMounted():在组件挂载完成后执行的函数,相当于Vue2中的mounted钩子函数。

  • onBeforeUpdate():在组件更新之前执行的函数,相当于Vue2中的beforeUpdate钩子函数。

  • onUpdated():在组件更新完成之后执行的函数,相当于Vue2中的updated钩子函数。

  • onBeforeUnmount():在组件卸载之前执行的函数,相当于Vue2中的beforeDestroy钩子函数。

  • onUnmounted():在组件卸载完成后执行的函数,相当于Vue2中的destroyed钩子函数。 onActivated():在组件被包含在<keep-alive>中,并且被激活时执行。除了以上的钩子函数之外,Vue3还提供了一些额外的钩子函数,如onRenderTriggeredonRenderTracked,用于在开发过程中进行调试。

Vue3中,可以使用<script setup>语法糖来定义组件的逻辑。使用<script setup>可以让代码更加简洁,阅读性更高。同时,Vue3还引入了自定义Hooks的概念,可以将一些逻辑抽象出来,实现代码的复用。

Vue3的生命周期钩子函数和Vue2的生命周期选项是如何合并在一起的呢?实际上,在Vue3的内部实现中,会将Vue3的钩子函数转换为Vue2的生命周期选项。具体来说,Vue3的钩子函数会被注册到Vue2的生命周期选项中,如下所示

function registerLifecycleHook(
    register: Function,
    hook?: Function | Function[]
  ) {
    if (isArray(hook)) {
      hook.forEach(_hook => register(_hook.bind(publicThis)))
    } else if (hook) {
      register((hook as Function).bind(publicThis))
    }
  }

在上面的代码中,registerLifecycleHook函数会将Vue3的钩子函数注册到Vue2的生命周期选项中。如果钩子函数是一个数组,那么会循环注册每一个钩子函数;如果钩子函数不是一个数组,那么只会注册一个钩子函数

Vue的钩子函数在Vue里面是一个很重要的知识点,以上是Vue2.0与Vue3.0生命周期

在哪个生命周期钩子函数里面处理什么业务逻辑,做什么事是非常重要的

用ChatGPT做了个App

2023-03-04

204ef141612d9ea55e2a6483aa1d23e1.jpeg

一文了解互联网中的运营

2023-03-03

41d344484ec060ea3c2cdac8a5f6e3a3.jpeg

从改简历到面试需要知道的

2023-03-02

943dbe77451607b936610b8868f0eb63.jpeg

入职前-求职者一定要提前了解的问题

2023-03-01

98bbc947a245a3c8b4c10168fae9fffe.jpeg

被面试官问到频繁跳槽,求职者应该怎么回

2023-02-28

822c971574f9008d13b9986080740935.jpeg

针对面试官的盘问-如何回答职场中的一些问题

2023-02-26

adf78580b08ff22059f615daa1215023.jpeg
点击左下角查看更多

81c641036b25ab47502cf9b6d507854d.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/401116.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

作为一名程序员少不了的软件

写在前面的话 就现今我自己接触的项目而言&#xff0c;我发现对于一名程序员来说有些软件是真的必不可少的&#xff0c;防止下次换电脑或者要换操作系统的时候用&#xff0c;特此记录一下。 一、最常使用的&#xff0c;JetBrain全家桶&#xff08;idea、pycharm、webstorm&…

【办公类-16-06-02】“2022下学期 总园活动室(沙水+建构)排班表(两周一次沙水)”(python 排班表系列)

作品展示&#xff1a;背景需求&#xff1a;上一篇批量制作了“7天轮回14班沙水每周固定建构”的活动室内排班表。一、时段冲突&#xff0c;调整单双周。保教主任抽空检查后&#xff0c;提到&#xff1a;“一个班、上午、下午都有自主游戏&#xff08;沙水、建构、表演、角色&am…

金三银四、金九银十 面试宝典 JAVASE八股文面试题 超级无敌全的面试题汇总(接近3万字的面试题,让你的JAVA语法基础无可挑剔)

JavaSE八股文 - 面试宝典 一个合格的 计算机打工人 &#xff0c;收藏夹里必须有一份 JAVA八股文面试题 &#xff0c;特别是即将找工作的计算机人&#xff0c;希望本篇博客对你有帮助&#xff01; 本文参考了诸多大佬的面试题帖子&#xff0c;ps&#xff1a;白大锅、哪吒、英雄…

从Linux内核中学习高级C语言宏技巧

Linux内核可谓是集C语言大成者&#xff0c;从中我们可以学到非常多的技巧&#xff0c;本文来学习一下宏技巧&#xff0c;文章有点长&#xff0c;但耐心看完后C语言level直接飙升。 本文出自&#xff1a;大叔的嵌入式小站&#xff0c;一个简单的嵌入式/单片机学习、交流小站 从…

机器看世界

博主简介 博主是一名大二学生&#xff0c;主攻人工智能研究。感谢让我们在CSDN相遇&#xff0c;博主致力于在这里分享关于人工智能&#xff0c;c&#xff0c;Python&#xff0c;爬虫等方面知识的分享。 如果有需要的小伙伴可以关注博主&#xff0c;博主会继续更新的&#xff0c…

为什么红黑树如此受欢迎

平衡二叉查找树有很多&#xff0c;但是我们一提到平衡二叉查找树&#xff0c;常提及的就是红黑树&#xff0c;它的“出镜率”甚至要高于平衡二叉查找树。 红黑树是一种相对平衡的二叉查找树&#xff0c;不符合严格意义上平衡二叉查找树的定义。 目录 红黑树的插入 红黑树的验…

SAP ABAP WebService

第一步&#xff1a;SE37 创建一个远程函数&#xff08;Remote Function Module&#xff09;注意该函数需要将Remote Enable开启第二步&#xff1a;创建WebService首先&#xff1a;SE37 打开需要关联的函数在菜单 Utilities->More Utilities->Create Web Service->From…

二 Go的基本语法

1. 基本类型 boolstringint、int8、int16、int32、int64uint、uint8、uint16、uint32、uint64、uintptrbyte // uint8 的别名rune // int32 的别名 代表一个 Unicode 码float32、float64complex64、complex128 2. 三种声明变量 2.1 标准格式 var name type 其中&#xff0c;…

MyBatis-Plus联表查询的短板,该如何解决呢

mybatis-plus作为mybatis的增强工具&#xff0c;它的出现极大的简化了开发中的数据库操作&#xff0c;但是长久以来&#xff0c;它的联表查询能力一直被大家所诟病。一旦遇到left join或right join的左右连接&#xff0c;你还是得老老实实的打开xml文件&#xff0c;手写上一大段…

链表及其基本操作

1.单链表&#xff1a;1.1定义/性质&#xff1a;链表是线性表的链式存储方式。单链表通过指针线性遍历&#xff0c;删除/增加节点时间复杂度为O(1&#xff09;,访问节点时间复杂度为O(n)。单链表分为带头结点和不带头结点两种&#xff0c;带头结点是为了方便统一操作&#xff08…

数据结构:链式二叉树初阶

目录 一.链式二叉树的逻辑结构 1.链式二叉树的结点结构体定义 2.链式二叉树逻辑结构 二.链式二叉树的遍历算法 1.前序遍历 2.中序遍历 3.后序遍历 4.层序遍历(二叉树非递归遍历算法) 层序遍历概念: 层序遍历算法实现思路: 层序遍历代码实现: 三.链式二叉树遍历算…

蓝桥杯三月刷题 第六天

文章目录&#x1f4a5;前言&#x1f609;解题报告&#x1f4a5;星期计算&#x1f914;一、思路:&#x1f60e;二、代码&#xff1a;&#x1f4a5;考勤刷卡&#x1f914;一、思路:&#x1f60e;二、代码&#xff1a;&#x1f4a5;卡片&#x1f914;一、思路:&#x1f60e;二、代…

Spring SpringBoot中使用Mybatis-plusDemo1

官网:https://baomidou.com GitHub:GitHub - baomidou/mybatis-plus: An powerful enhanced toolkit of MyBatis for simplify development Gitee:mybatis-plus: mybatis 增强工具包&#xff0c;简化 CRUD 操作。 文档 http://baomidou.com低代码组件库 http://aizuda.com My…

Leetcode.剑指 Offer II 023. 两个链表的第一个重合节点

题目链接 Leetcode.剑指 Offer II 023. 两个链表的第一个重合节点 easy 题目描述 给定两个单链表的头节点 headA和 headB&#xff0c;请找出并返回两个单链表相交的起始节点。如果两个链表没有交点&#xff0c;返回 null。 注意&#xff0c;函数返回结果后&#xff0c;链表必…

Lumion 2023即将上线,低配电脑如何驾驭Lumion

年更选手Lumion的更新速度“从不让人失望”&#xff0c;自从Lumion 12更新完之后&#xff0c;官方意料之中的没了动静。但是就在这几天&#xff0c;官方终于放出了首支Lumion 2023的更新预告&#xff0c;并且宣布将于本月中旬发布&#xff01;Lumion 2023主要变化是支持光线追踪…

【Linux:环境变量的理解】

目录 1 Z(zombie)-僵尸进程 2 孤儿进程 3 环境变量 3.1 基本概念 3.2 测试HOME 3.3 和环境变量相关的命令 3.4 环境变量的组织方式 3.5 环境变量通常是具有全局属性的 在讲环境变量之前&#xff0c;我们先把上次遗留知识点给总结了&#xff08;僵尸进程和孤儿进程&…

fast-api 一款快速将spring的bean发布成接口并生产对应swagger文档调试的轻量级工具

fast-api简介背景开发痛点:分析需求实战fast-api快速上手1. 引入依赖2. FastApiMapping标记service对象3. swagger2/knife4j 在线测试进阶使用开启调试模式支持指定类或包目录发布如何关闭fast-api自定义fast-api的前缀写在最后简介 fast-api 一款快速将spring的bean(service)发…

案例学习6-没有复用思想

背景&#xff1a; 上述两个方法查询同一张表&#xff0c;只是数据结构不同&#xff0c;完全可以合成一份方法&#xff0c;减少代码冗余。 实现效果如下 不传参&#xff0c;查询所有的数据 传入特定参数实现按条件查询&#xff1a; 实现方式&#xff1a; GetMapping(value &q…

Antlr Tool与antlr runtime的版本一致性问题

1. 意外的问题 在学习Antlr4的visitor模式时&#xff0c;使用IDEA的Antlr插件完成了Hello.g4文件的编译&#xff0c;指定的package为com.sunrise.hello 使用visitor模式遍历语法解析树&#xff0c;遍历过程中打印hello语句 public class HelloVisitorImpl extends HelloBaseVi…

Linux进程和任务管理和分析和排查系统故障

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a;小刘主页 ♥️每天分享云计算网络运维课堂笔记&#xff0c;努力不一定有收获&#xff0c;但一定会有收获加油&#xff01;一起努力&#xff0c;共赴美好人生&#xff01; ♥️夕阳下&#xff0c;是最美的绽放&#xff0…