【前端高频面试题--Vue生命周期篇】

🚀 作者 :“码上有前”
🚀 文章简介 :前端高频面试题
🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬

在这里插入图片描述

前端高频面试题--Vue生命周期篇

  • 往期精彩内容
  • Vue的生命周期
  • Vue子组件和父组件执行顺序
  • 在哪个生命周期请求异步数据
  • keep-alive 中的生命周期哪些

往期精彩内容

【前端高频面试题–HTML篇】
【前端高频面试题–CSS上篇】
【前端高频面试题–CSS下篇】
【前端高频面试题–JS上篇】
【前端高频面试题–JS下篇】
【前端高频面试题–ES6篇】
【前端高频面试题–ES7-ES11】
【前端–异步编程】
【前端高频面试题–TypeScript篇】

【前端高频面试题–git篇】
【前端高频面试题–微信小程序篇】

【前端高频面试题–Vue基础篇】
【前端高频面试题–虚拟DOM篇】
【前端高频面试题–Vue3.0篇】
【前端高频面试题–Vuex上篇】
【前端高频面试题–Vuex下篇】
【前端高频面试题–Vue生命周期篇】
【前端高频面试题–Vue组件通信篇】
【前端高频面试题–Vue路由篇】

【前端-Vue3创建一个新项目】
【前端大屏自适应缩放】
【前端Vue3 + TS项目开发一般流程】

Vue的生命周期

看下面这张图就够啦 🚀

在这里插入图片描述

Vue.js 的生命周期是指在组件创建、挂载、更新和销毁过程中触发的一系列钩子函数。这些钩子函数可以让我们在特定的时刻执行自定义的逻辑。

Vue.js 的生命周期可以分为以下几个阶段:

  1. 创建阶段

    • beforeCreate:在实例被创建之后,但是在数据观测和事件/钩子函数初始化之前调用。此时,组件的数据和方法还未初始化。
    • created:在实例创建完成后调用。此时,组件的数据已经初始化,可以访问 data 中的数据和 methods 中的方法,但尚未挂载到 DOM 上。
  2. 挂载阶段

    • beforeMount:在挂载开始之前被调用。此时,模板已经编译完成,但尚未将模板渲染到真实的 DOM 中。
    • mounted:在挂载完成后被调用。此时,组件已经被挂载到 DOM 上,可以进行 DOM 操作,也可以访问到通过 ref 获取的 DOM 元素。
  3. 更新阶段

    • beforeUpdate:在数据更新之前调用。此时,已经接收到新的数据,但是 DOM 尚未更新。
    • updated:在数据更新完成后调用。此时,组件的数据已经更新,DOM 也已经重新渲染。
  4. 销毁阶段

    • beforeUnmount(Vue 2.x)/ beforeDestroy(Vue 3.x):在实例销毁之前调用。此时,组件实例仍然完全可用。
    • unmounted(Vue 2.x)/ unmounted(Vue 3.x):在实例销毁后调用。此时,组件实例已经被销毁,对应的 DOM 也会被移除。

除了上述的主要生命周期钩子函数外,Vue 还提供了其他一些较少使用的钩子函数,例如 activated(组件被激活时调用)和 deactivated(组件被停用时调用),以及 errorCaptured(捕获组件内部错误)等。

在生命周期函数中,我们可以执行一些初始化操作、发送网络请求、订阅事件、操作 DOM 等。生命周期函数提供了一种管理组件行为的方式,使我们能够在不同的时刻执行相应的逻辑。

需要注意的是,在 Vue 3 中,一些生命周期钩子函数的名称发生了变化,例如 beforeMount 在 Vue 3 中被重命名为 beforeMount,beforeUnmount 取代了 beforeDestroy。这是由于 Vue 3 采用了 Composition API 的新特性,以及对应用程序的性能优化进行了改进。

Vue子组件和父组件执行顺序

在 Vue 中,子组件和父组件的生命周期钩子函数的执行顺序如下:

  1. 父组件:

    • beforeCreate
    • created
    • beforeMount
    • 子组件的 beforeCreate 和 created 钩子函数
    • mounted
    • 子组件的 beforeMount 和 mounted 钩子函数
  2. 子组件:

    • beforeCreate
    • created
    • beforeMount
    • mounted

在父组件的生命周期中,子组件的 beforeCreate 和 created 钩子函数会在父组件的 beforeCreate 和 created 钩子函数之后执行。因为子组件的实例化和初始化是在父组件的 created 钩子函数之后进行的。

在父组件的 beforeMount 和 mounted 钩子函数中,子组件的 beforeMount 和 mounted 钩子函数会在父组件的 beforeMount 和 mounted 钩子函数之后执行。这是因为在父组件的 mount 过程中,会先处理父组件的模板,然后才会处理子组件的模板。

需要注意的是,父组件的 updated 钩子函数会在子组件的 updated 钩子函数之后执行。这是因为在更新过程中,先更新子组件,然后再更新父组件。

总的来说,父组件的生命周期钩子函数会在子组件的生命周期钩子函数之前执行,而在子组件的生命周期钩子函数中,beforeCreate 和 created 钩子函数会在 beforeMount 和 mounted 钩子函数之前执行。这样的顺序确保了父子组件之间的正确初始化和挂载过程。

在哪个生命周期请求异步数据

在 Vue.js 中,常常在组件的 “created” 生命周期钩子函数中请求异步数据。“created” 钩子函数是在组件实例创建完成之后立即被调用的,并且此时组件的数据已经初始化,可以进行异步请求。

在 “created” 钩子函数中请求异步数据的常见做法是使用异步函数(如 axios、fetch 等)或者调用组件自定义的方法来发起请求。通过异步请求获取到的数据可以保存在组件的 data 属性中,从而在模板中进行渲染。

以下是一个示例代码,展示了如何在 Vue 组件的 “created” 钩子函数中请求异步数据:

<template>
  <div>
    <ul>
      <li v-for="item in items" :key="item.id">{{ item.title }}</li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      items: []  // 初始化数据为空数组
    };
  },
  created() {
    this.fetchData(); // 在 created 钩子函数中调用 fetchData 方法
  },
  methods: {
    fetchData() {
      // 发起异步请求
      // 假设使用 axios 库进行请求
      axios.get('https://api.example.com/items')
        .then(response => {
          this.items = response.data; // 将获取到的数据保存到组件的 data 属性中
        })
        .catch(error => {
          console.error(error);
        });
    }
  }
};
</script>

在上述示例中,我们在 “created” 钩子函数中调用了 “fetchData” 方法来发起异步请求,并将获取到的数据保存在组件的 “items” 数据属性中。这样,当组件被创建后,异步数据会被加载并在模板中进行渲染。

keep-alive 中的生命周期哪些

在 Vue.js 中,使用 <keep-alive> 组件可以将动态组件进行缓存,以避免组件的重复创建和销毁,提高性能。当组件被 <keep-alive> 包裹时,它会有一些特殊的生命周期钩子函数。

以下是 <keep-alive> 组件中的生命周期钩子函数:

  • activated:在被包裹的组件被激活时调用。当组件切换到活跃状态时(从缓存中取出),会触发该钩子函数。
  • deactivated:在被包裹的组件被停用时调用。当组件切换到非活跃状态时(被缓存),会触发该钩子函数。

这两个钩子函数的使用场景如下:

  • activateddeactivated 钩子函数通常用于需要在组件切换时执行一些特定逻辑的场景,例如在组件切换到活跃状态时重新加载数据,或者在组件切换到非活跃状态时清除不必要的资源。

需要注意的是,activateddeactivated 钩子函数只对被 <keep-alive> 包裹的组件生效,对于其他组件不会触发。

以下是示例代码,演示了在 <keep-alive> 组件中使用 activateddeactivated 钩子函数:

<template>
  <div>
    <h1>{{ message }}</h1>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Hello!',
    };
  },
  activated() {
    console.log('Component activated');
    // 在组件被激活时执行特定逻辑,例如重新加载数据
    this.loadData();
  },
  deactivated() {
    console.log('Component deactivated');
    // 在组件被停用时执行特定逻辑,例如清除资源
    this.clearData();
  },
  methods: {
    loadData() {
      // 加载数据逻辑
    },
    clearData() {
      // 清除资源逻辑
    },
  },
};
</script>

在上述示例中,当组件被 <keep-alive> 包裹时,每当组件被激活或停用时,activateddeactivated 钩子函数会被触发,并执行相应的逻辑。
都看到这了,点个赞吧,嘿嘿🚀

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

协调尺度:特征缩放在机器学习中的重要作用

目录 一、介绍 二、背景知识 三、了解功能缩放 四、特征缩放方法 五、特征缩放的重要性 六、实际意义 七、代码 八、结论 一、介绍 特征缩放是机器学习和数据分析预处理阶段的关键步骤&#xff0c;在优化各种算法的性能和效率方面起着至关重要的作用。本文深入探讨了特征缩放的…

【论文精读】DALL·E

摘要 本文利用从互联网上收集的2.5亿个图像/文本对数据&#xff0c;训练了一个120亿参数的自回归transformer&#xff0c;进而得到一个可以通过自然语言/图像控制生成的高保真图像生成模型。在大多数数据集上的表现超越以往的方法。 框架 本文的目标为通过训练一个自回归trans…

结构体对齐规则及为什么会有结构体对齐

前言&#xff1a; 大家在学习结构体中&#xff0c;在计算结构体大小时想必会很疑惑&#xff0c;为什么结构体的大小不是按照常理像数组一样一个字节一个字节的挨在一起放&#xff1f;今天带大家一起深入探讨一下背后的规则和原因。 结构体对齐规则&#xff1a; 结构体对齐其实…

BUUCTF misc 专题(47)[SWPU2019]神奇的二维码

下载附件&#xff0c;得到一张二维码图片&#xff0c;并用工具扫描&#xff08;因为图片违规了&#xff0c;所以就不放了哈。工具的话&#xff0c;一般的二维码扫描都可以&#xff09; swpuctf{flag_is_not_here}&#xff0c;&#xff08;刚开始出了点小差错对不住各位师傅&am…

进程间通信——管道

文章目录 进程间通信的介绍进程间通信的目的进程间通信的本质 匿名管道创建管道匿名管道的特征 命名管道小结 进程间通信的介绍 进程间通信简称IPC&#xff08;Interprocess communication&#xff09;&#xff0c;进程间通信就是在不同进程之间传播或交换信息。 进程间通信的…

分布式文件系统 SpringBoot+FastDFS+Vue.js【三】

分布式文件系统 SpringBootFastDFSVue.js【三】 七、创建后台--分角色管理7.1.创建后台数据库表7.2.创建实体类7.2.1.Admin7.2.2.Menu7.2.3.MenuBean7.2.4.Role7.2.5.RoleMenu 7.3.编辑配置文件application.yml7.4.编写工具类7.4.1.AuthContextHolder7.4.2.HttpUtils7.4.3.Stri…

成员方法传参机制

一、成员方法传参机制 1、值传递&#xff1a;形参改变不影响实参 2、地址传递&#xff1a;形参改变影响实参

函数式编程的技巧

14.1.2 科里化 给出科里化的理论定义之前&#xff0c;让我们先来看一个例子。应用程序通常都会有国际化的需求将一套单位转换到另一套单位是经常碰到的问题。 单位转换通常都会涉及转换因子以及基线调整因子的问题。比如&#xff0c;将摄氏度转换到华氏度的公式是CtoF(x)x*9/…

【高级C语言】从汇编代码看volatile关键字的作用

本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客内容主要围绕&#xff1a; 5G/6G协议讲解 算力网络讲解&#xff08;云计算&#xff0c;边缘计…

apk反编译修改教程系列---简单去除apk登陆 修改vip与一些反编译基础常识【十二】

往期教程&#xff1a; 安卓玩机-----反编译apk 修改apk 去广告 去弹窗等操作中的一些常识apk反编译修改教程系列-----修改apk应用名称 任意修改名称 签名【一】 apk反编译修改教程系列-----任意修改apk版本号 版本名 防止自动更新【二】 apk反编译修改教程系列-----修改apk中…

政安晨:【示例演绎】【Python】【Numpy数据处理】快速入门(二)

环境准备 大家如果第一次看到&#xff0c;可以先从我这个演绎系列的第一篇文章开始&#xff0c;包括准备环境等等。 第一篇文章如下&#xff1a; 政安晨&#xff1a;【示例演绎】【Python】【Numpy数据处理】快速入门&#xff08;一&#xff09;https://blog.csdn.net/snowd…

怎么搭建自己的网站?

怎么搭建自己的网站 一.领取一个免费域名和SSL证书&#xff0c;和CDN 特点&#xff1a;支持Cloudflare CDN Cloudflare是全球知名的CDN提供商&#xff0c;如果你不想暴露你的源站&#xff0c;又想使用我们的二级域名&#xff0c;不需要前往Cloudflare添加域名&#xff0c;修…

【Linux取经路】文件系统之被打开的文件——文件描述符的引入

文章目录 一、明确基本共识二、C语言文件接口回顾2.1 文件的打开操作2.2 文件的读取写入操作2.3 三个标准输入输出流 三、文件有关的系统调用3.1 open3.1.1 比特位级别的标志位传递方式 3.2 write3.2.1 模拟实现 w 选项3.2.2 模拟实现 a 选项 3.3 read 四、访问文件的本质4.1 再…

STM32,嵌入式系统中的I2C协议

I2C协议——读写EEPROM 关注我&#xff0c;共同交流&#xff0c;一起成长 前言一、协议简介二、I2C特性及架构三、通信过程 前言 这是一种主要用于集成电路和集成电路&#xff08;IC&#xff09;通信&#xff0c;计算机中复杂的问题大多数就是用分层来进行解决&#xff0c;这个…

k8s-项目部署案例

一、容器交付流程 在k8s平台部署项目流程 在K8s部署Java网站项目 DockerFile 如果是http访问&#xff0c;需要在镜像仓库配置可信任IP 三、使用工作负载控制器部署镜像 建议至少配置两个标签 一个是声明项目类型的 一个是项目名称的 继续配置属性 资源配额 健康检查 五、使…

积分(二)——复化Simpson(C++)

前言 前言 simpson积分 simpson积分公式 ∫ a b f ( x ) d x ≈ b − a 6 [ f ( a ) f ( b ) 4 f ( a b 2 ) ] \int_{a}^{b}f(x)dx \approx \frac{b-a}{6}[f(a)f(b)4f(\frac{ab}{2})] ∫ab​f(x)dx≈6b−a​[f(a)f(b)4f(2ab​)] 与梯形积分类似&#xff0c;当区间[a,b]较…

Java 和 JavaScript 的奇妙协同:语法结构的对比与探索(下)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

卷积神经网络的基本结构

卷积神经网络的基本结构 与传统的全连接神经网络一样&#xff0c;卷积神经网络依然是一个层级网络&#xff0c;只不过层的功能和形式发生了变化。 典型的CNN结构包括&#xff1a; 数据输入层&#xff08;Input Layer&#xff09;卷积层&#xff08;Convolutional Layer&#x…

社区商铺开什么店最好?从商业计划书到实际运营

在社区商铺开店&#xff0c;选择适合的业态是成功的关键。作为一名开店 5 年的资深创业者&#xff0c;我想分享一些关于社区店的干货和见解。 这篇文章&#xff0c;我用我的项目给大家举例子&#xff01; 鲜奶吧作为一种新兴的业态&#xff0c;以提供新鲜、健康的乳制品为主&…

vue3 之 倒计时函数封装

理解需求 编写一个函数useCountDown可以把秒数格式化为倒计时的显示xx分钟xx秒 1️⃣formatTime为显示的倒计时时间 2️⃣start是倒计时启动函数&#xff0c;调用时可以设置初始值并且开始倒计时 实现思路分析 安装插件 dayjs npm i dayjs倒计时逻辑函数封装 // 封装倒计时…