当前位置: 首页 > news >正文

Vue3.0生命周期钩子(包含:Vue 2.0 和 Vue 3.0)

1、Vue 2.0 生命周期钩子

每个应用程序实例在创建时都有一系列的初始化步骤。例如,创建数据绑定、编译模板、将实例挂载到 DOM 并在数据变化时触发 DOM 更新、销毁实例等。在这个过程中会运行一些叫做生命周期钩子的函数,通过这些钩子函数可以定义业务逻辑。应用程序实例中几个主要的生命周期钩子函数的说明如下:

钩子函数说明
beforeCreate()在实例初始化之后且数据观测和事件/监听器配置之前调用。
created()在实例创建之后进行调用,此时尚未开始 DOM 编译。在需要初始化处理一些数据时会比较有用。
beforeMount()在挂载开始之前进行调用,此时 DOM 还无法操作。
mounted()在 DOM 文档渲染完毕之后进行调用。相当于 JavaScript 中的 windos.onload() 方法。
beforeUpdate()在数据更新时进行调用,适合在更新之前访问现在的 DOM,如手动移除已添加的事件监听器。
updated()在数据更新导致的虚拟 DOM 被重新渲染时进行调用。
beforeDestroy()在销毁实例之前进行调用,此时实例仍然有效。此时可以解绑一些使用 addEventListener 监听的事件等。
destroyed()在实例被销毁之后进行调用。

【实例】使用生命周期钩子,了解 Vue.js 内部的运行机制。

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Vue生命周期钩子</title>
</head><body><div id="app"><p>{{text}}</p></div>
</body><!-- 引入 Vue 框架 -->
<script src="../js/vue.global.js"></script><script type="text/javascript">//创建应用程序实例const vueApp = Vue.createApp({//返回数据对象data() {return {text: "千里之行,始于足下"}},//生命周期钩子beforeCreate: function () {console.log("beforCreate");},created: function () {console.log("created");},beforeMount: function () {console.log("beforeMount");},mounted: function () {console.log("mounted");},beforeUpdate: function () {console.log("beforeUpdate");},updated: function () {console.log("updated");}//转载应用程序实例的根组件}).mount("#app");//使用定时器函数,2秒后修改内容setTimeout(function () {console.log("修改数据内容:")vueApp.text = "水不在深,有龙则灵";}, 2000);
</script></html>

执行结果:

当2秒后调用 setTimeout() 方法,修改 text 的内容,触发 beforeUpdate() 和 updated() 钩子函数。

2、Vue 3.0 生命周期钩子

Vue3.0 是兼容 Vue2.x 版本的也就是说我们再日常工作中可以在 Vue3 中使用 Vue2.x 的相关语法。

Vue 3.0 带来了许多新特性和改进,其中包括更强大的组合 API。与基于选项的 API 相比,组合 API 中的生命周期钩子函数也发生了变化,将选项中的生命周期钩子函数改成了 onXxx() 函数的形式。

需要注意:

1、beforeCreate() 和 created() 两个钩子函数已被删除了,取而代之的是 setup() 函数。

2、组合 API 中的生命周期钩子函数都是在 setup() 函数内部通过引入相应的函数来使用的。

Vue 3.0 中新增的钩子函数主要包括:

组合 API 钩子函数说明
setup()

setup() 函数是一个新的组件选项,它是组件内部使用组合 API 的入口。

setup() 函数在组件实例创建之前、初始化 Prop 之后调用。

setup() 函数可以返回一个对象或函数,对象的属性会合并到组件模板渲染的上下文中。

onBeforeMount()组件挂载到节点上之前执行的函数。
onMounted()组件挂载完成后执行的函数。
onBeforeUpdate()组件更新之前执行的函数。
onUpdated()组件更新完成之后执行的函数。
onBeforeUnmount()组件卸载之前执行的函数
onUnmounted()组件卸载完成后执行的函数。
onActivated()被包含在 <keep-alive> 中的组件,会多出两个生命周期钩子函数,被激活时执行。
onDeactivated()比如从 A 组件,切换到 B 组件,A 组件消失时执行。
onErrorCaptured()当捕获一个来自子孙组件的异常时激活钩子函数。

Vue2.0 和 Vue3.0 生命周期钩子函数对比:

【实例】创建一个组件,实现一个计数器功能。

<template><div><h3>{{ blogInfo.name }}</h3><h3>{{ blogInfo.url }}</h3><p>计数结果:{{ count }}</p><button @click="counter">计数器</button></div>
</template><script>
import { ref, reactive, onMounted, onUnmounted } from 'vue';export default {setup() {// 使用 ref 创建响应式的基本类型const count = ref(0);// 使用 reactive 创建响应式的复杂类型const blogInfo = reactive({name: '您好,欢迎访问 pan_junbiao的博客',url: 'https://blog.csdn.net/pan_junbiao'});// 挂载时的操作onMounted(() => {console.log('组件已挂载');});// 卸载时的操作onUnmounted(() => {console.log('组件已卸载');});// 增加计数的方法function counter() {count.value++;}// 返回需要在模板中使用的数据和方法return {blogInfo,count,counter};}
};
</script>

 执行结果:

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • JavaEE 的相关知识点(一)
  • [000-002-01].数据库调优相关学习
  • python提取b站视频的音频(提供源码
  • 华为---端口隔离简介和示例配置
  • 牛客周赛 Round 56
  • 索引——appinventor
  • Spring Boot 实现定时任务
  • mysql实现分布式锁
  • 力学笃行(五)Qt key绑定、钩子(hook)
  • H5漂流瓶交友源码_社交漂流瓶H5源码
  • csrf漏洞(二)
  • GNS3 IOU: License section not found in iourc file /tmp/tmpj54abrhf/iourc
  • day01-作业题
  • 深度学习入门(E):逻辑回归与分类到底是啥关系?
  • CoOp(论文解读):Learning to Prompt for Vision-Language Models
  • JS 中的深拷贝与浅拷贝
  • 【跃迁之路】【699天】程序员高效学习方法论探索系列(实验阶段456-2019.1.19)...
  • 2017 年终总结 —— 在路上
  • 3.7、@ResponseBody 和 @RestController
  • CSS进阶篇--用CSS开启硬件加速来提高网站性能
  • Go 语言编译器的 //go: 详解
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • input的行数自动增减
  • Java知识点总结(JavaIO-打印流)
  • select2 取值 遍历 设置默认值
  • Three.js 再探 - 写一个跳一跳极简版游戏
  • Vue 动态创建 component
  • weex踩坑之旅第一弹 ~ 搭建具有入口文件的weex脚手架
  • yii2权限控制rbac之rule详细讲解
  • 百度贴吧爬虫node+vue baidu_tieba_crawler
  • 初识 webpack
  • 第三十一到第三十三天:我是精明的小卖家(一)
  • 互联网大裁员:Java程序员失工作,焉知不能进ali?
  • 聚簇索引和非聚簇索引
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 如何实现 font-size 的响应式
  • 什么软件可以提取视频中的音频制作成手机铃声
  • 跳前端坑前,先看看这个!!
  • 网页视频流m3u8/ts视频下载
  • ###51单片机学习(2)-----如何通过C语言运用延时函数设计LED流水灯
  • #Spring-boot高级
  • $(function(){})与(function($){....})(jQuery)的区别
  • (echarts)echarts使用时重新加载数据之前的数据存留在图上的问题
  • (LLM) 很笨
  • (STM32笔记)九、RCC时钟树与时钟 第一部分
  • (九十四)函数和二维数组
  • (论文阅读32/100)Flowing convnets for human pose estimation in videos
  • (每日一问)设计模式:设计模式的原则与分类——如何提升代码质量?
  • (三维重建学习)已有位姿放入colmap和3D Gaussian Splatting训练
  • (五十)第 7 章 图(有向图的十字链表存储)
  • (学习日记)2024.03.12:UCOSIII第十四节:时基列表
  • (一) 初入MySQL 【认识和部署】
  • (原+转)Ubuntu16.04软件中心闪退及wifi消失
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • (转)Android学习系列(31)--App自动化之使用Ant编译项目多渠道打包