生命周期总结(uni-app、vue2、vue3生命周期讲解)
一、vue2生命周期
Vue2 的生命周期钩子函数分为 4 个阶段:创建、挂载、更新、销毁。
1. 创建阶段
-
beforeCreate:实例初始化之后,数据观测和事件配置之前。 -
created:实例创建完成,数据观测和事件配置已完成,但 DOM 未生成。
2. 挂载阶段
-
beforeMount:模板编译完成,但未挂载到 DOM。 -
mounted:实例挂载到 DOM 后调用,DOM 已生成。
3. 更新阶段
-
beforeUpdate:数据更新时调用,DOM 未重新渲染。 -
updated:数据更新后,DOM 重新渲染完成。
4. 销毁阶段
-
beforeDestroy:实例销毁之前调用,此时实例仍可用。 -
destroyed:实例销毁后调用,所有事件监听器和子实例被移除。
export default {beforeMount() {console.log('beforeMount: 模板编译完成,DOM 未挂载');},mounted() {console.log('mounted: DOM 已挂载');}
}
二、vue3生命周期
Vue3 的生命周期与 Vue2 类似,但有一些变化:
Vue3 使用 Composition API,生命周期钩子函数可以通过
setup函数访问。部分钩子函数名称变化,并新增了一些钩子。
1. 创建阶段
-
setup:替代beforeCreate和created,在组件初始化时调用。 -
onBeforeMount:替代beforeMount。 -
onMounted:替代mounted。
2. 更新阶段
-
onBeforeUpdate:替代beforeUpdate。 -
onUpdated:替代updated。
3. 销毁阶段
-
onBeforeUnmount:替代beforeDestroy。 -
onUnmounted:替代destroyed。
4. 新增钩子
-
onActivated:被<keep-alive>缓存的组件激活时调用。 -
onDeactivated:被<keep-alive>缓存的组件停用时调用。 -
onErrorCaptured:捕获子孙组件的错误时调用。
import { onBeforeMount, onMounted } from 'vue';export default {setup() {console.log('setup: 组件初始化');onBeforeMount(() => {console.log('onBeforeMount: DOM 未挂载');});onMounted(() => {console.log('onMounted: DOM 已挂载');});}
}
三、vue2和vue3生命周期的区别
| 生命周期 | Vue2 | Vue3 | 说明 |
|---|---|---|---|
| 创建阶段 | beforeCreate | setup | Vue3 使用 setup 替代 beforeCreate 和 created |
| 挂载阶段 | beforeMount | onBeforeMount | 钩子函数名称变化 |
| 挂载完成 | mounted | onMounted | 钩子函数名称变化 |
| 更新阶段 | beforeUpdate | onBeforeUpdate | 钩子函数名称变化 |
| 更新完成 | updated | onUpdated | 钩子函数名称变化 |
| 销毁阶段 | beforeDestroy | onBeforeUnmount | 钩子函数名称变化 |
| 销毁完成 | destroyed | onUnmounted | 钩子函数名称变化 |
| 缓存组件激活 | 无 | onActivated | Vue3 新增 |
| 缓存组件停用 | 无 | onDeactivated | Vue3 新增 |
| 错误捕获 | 无 | onErrorCaptured | Vue3 新增 |
四、uni-app生命周期
UniApp 的生命周期分为 应用生命周期、页面生命周期 和 组件生命周期。
官网链接:页面 | uni-app官网
1、应用的生命周期(重点是前面几个)
-
onLaunch:应用初始化完成时触发(全局只触发一次)。 -
onShow:应用启动或从后台进入前台时触发。 -
onHide:应用从前台进入后台时触发。 -
onError:应用发生脚本错误时触发。 -
onUniNViewMessage:监听nvue页面发送的消息。 -
onUnhandledRejection:监听未处理的 Promise 拒绝事件。 -
onPageNotFound:页面不存在时触发。 -
onThemeChange:监听系统主题变化。
// 在 App.vue 中定义应用生命周期钩子
export default {onLaunch(options) {console.log('App Launch', options);},onShow(options) {console.log('App Show', options);},onHide() {console.log('App Hide');},onError(err) {console.error('App Error', err);}
}
2、页面的生命周期(前五个是重点)
页面生命周期是指单个页面的加载、显示、隐藏和卸载的过程。Uniapp 提供了以下页面生命周期钩子函数:
-
onLoad: 页面加载时触发,一个页面只会调用一次,参数为页面传递的参数。适合在页面加载时获取参数并初始化数据。
-
onShow: 页面显示/切入前台时触发。刷新也会触发。
-
onReady: 页面初次渲染完成时触发,一个页面只会调用一次。
-
onHide: 页面隐藏/切入后台时触发。
-
onUnload: 页面卸载时触发。
-
onPullDownRefresh: 页面下拉刷新时触发。
-
onReachBottom: 页面上拉触底时触发。
-
onPageScroll: 页面滚动时触发。
-
onResize: 页面尺寸改变时触发(如屏幕旋转)。
-
onTabItemTap: 点击 tab 时触发,参数为当前 tab 的信息。
// 在页面中定义页面生命周期钩子
export default {onLoad(options) {console.log('Page Load', options);},onShow() {console.log('Page Show');},onReady() {console.log('Page Ready');},onHide() {console.log('Page Hide');},onUnload() {console.log('Page Unload');}
}
注意:onLoad和onReady的区别
onload:
- 触发时机较晚,需要等待页面及其所有元素(包括图片、视频等)完全加载完毕后才会触发。
- 适用于需要在页面所有资源都加载完毕后才执行的操作,如计算页面元素的大小、位置等属性。
- 在传统的网页开发中,onload事件经常被用来确保页面资源已经加载完毕后再执行某些操作。
- 使用场景:如果你需要确保页面上的所有元素都已经加载完毕再发起请求,比如获取某些依赖于页面内容的动态数据,那么onload是一个合适的选择。这样可以避免因为页面元素还未加载完毕而导致的请求错误或数据不准确。
onready:
- 触发时机较早,当页面DOM结构绘制完毕后就会触发。
- 适用于需要在页面DOM结构就绪后立即执行的操作,如初始化UI组件、绑定事件监听器等。
- 在一些现代前端框架(如Vue、React等)中,通常会有类似的生命周期钩子(如mounted)来替代传统的onready事件。
- 使用场景:如果你需要在页面DOM结构就绪后立即发起请求,而不必等待所有资源都加载完毕,那么onready更为合适。这通常用于初始化页面上的某些功能或组件,这些功能或组件可能不依赖于页面上的所有资源。
3、组件的生命周期
UniApp 的组件生命周期与 Vue2 或 Vue3 的生命周期一致,如果使用的是vue2则使用vue2的生命周期,使用的vue3,则使用vue3生命周期。
Vue2:
beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy、destroyed。Vue3:
setup、onBeforeMount、onMounted、onBeforeUpdate、onUpdated、onBeforeUnmount、onUnmounted。
4、为什么应用和页面生命周期都包含 onShow 和 onHide
-
应用生命周期 的
onShow和onHide是针对整个应用的,关注的是应用的整体状态(如启动、切换到前台/后台)。 -
页面生命周期 的
onShow和onHide是针对单个页面的,关注的是页面的显示和隐藏状态(如页面跳转、返回)。
5、两者生命周期的区别
| 特性 | 应用生命周期 (App.vue) | 页面生命周期 (页面 .vue) |
|---|---|---|
| 作用范围 | 整个应用 | 单个页面 |
| 触发时机 | 应用启动、切换到前台/后台 | 页面显示、隐藏 |
| 使用场景 | 全局逻辑(如登录状态检查) | 页面逻辑(如刷新数据) |
五、总结
-
Vue2 和 Vue3 的生命周期基本一致,但 Vue3 引入了 Composition API,部分钩子函数名称变化,并新增了一些钩子。
-
UniApp 的生命周期分为应用、页面和组件三部分,应用和页面的生命周期是 UniApp 特有的,组件的生命周期与 Vue 一致。
-
在实际开发中,根据框架版本(Vue2/Vue3)和平台(UniApp)选择合适的生命周期钩子函数。
-
发起请求的时机:
-
页面加载时:
onLoad -
页面显示时:
onShow -
下拉刷新时:
onPullDownRefresh -
上拉加载更多时:
onReachBottom -
组件创建时:
created或mounted
-
相关文章:
生命周期总结(uni-app、vue2、vue3生命周期讲解)
一、vue2生命周期 Vue2 的生命周期钩子函数分为 4 个阶段:创建、挂载、更新、销毁。 1. 创建阶段 beforeCreate:实例初始化之后,数据观测和事件配置之前。 created:实例创建完成,数据观测和事件配置已完成,…...
十一、Redis Sentinel(哨兵)—— 高可用架构与配置指南
Redis Sentinel(哨兵)—— 高可用架构与配置指南 在分布式应用中,Redis 主从复制(Master-Slave)虽然能提供读写分离的能力,但它 无法自动故障转移(failover)。如果主节点(Master)发生故障,系统管理员需要手动将某个从节点(Slave)提升为主节点,并重新配置所有从节…...
java8中young gc的垃圾回收器选型,您了解嘛
在 Java 8 的 Young GC(新生代垃圾回收)场景中,对于 ToC的场景,即需要尽可能减少垃圾回收停顿时间以满足业务响应要求的场景,以下几种收集器各有特点,通常 Parnew和 G1 young表现较为出色,下面详…...
C语言学习笔记-初阶(30)深入理解指针2
1. 数组名的理解 在上一个章节我们在使用指针访问数组的内容时,有这样的代码: int arr[10] {1,2,3,4,5,6,7,8,9,10}; int *p &arr[0]; 这里我们使用 &arr[0] 的方式拿到了数组第⼀个元素的地址,但是其实数组名本来就是地址&…...
【Wireshark 02】抓包过滤方法
一、官方教程 Wireshark 官网文档 : Wireshark User’s Guide 二、显示过滤器 2.1、 “数据包列表”窗格的弹出过滤菜单 例如,源ip地址作为过滤选项,右击源ip->prepare as filter-> 选中 点击选中完,显示过滤器&#…...
MySQL基础四(JDBC)
JDBC(重点) 数据库驱动 程序会通过数据库驱动,和数据库打交道。 sun公司为了简化开发人员对数据库的统一操作,提供了一个Java操作数据库的规范。这个规范由具体的厂商去完成。对应开发人员来说,只需要掌握JDBC接口。 熟悉java.sql与javax.s…...
基于CURL命令封装的JAVA通用HTTP工具
文章目录 一、简要概述二、封装过程1. 引入依赖2. 定义脚本执行类 三、单元测试四、其他资源 一、简要概述 在Linux中curl是一个利用URL规则在命令行下工作的文件传输工具,可以说是一款很强大的http命令行工具。它支持文件的上传和下载,是综合传输工具&…...
cenos7网络安全检查
很多网络爱好者都知道,在Windows 2000和Windows 9x的命令提示符下可使用Windows系统自带的多种命令行网络故障检测工具,比如说我们最常用的ping。但大家在具体应用时,可能对这些命令行工具的具体含义,以及命令行后面可以使用的种…...
FastGPT 引申:混合检索完整实例
文章目录 FastGPT 引申:混合检索完整实例1. 各检索方式的初始结果2. RRF合并过程3. 合并后的结果4. Rerank重排序后5. 最终RRF合并6. 内容总结 FastGPT 引申:混合检索完整实例 下边通过一个简单的例子说明不同检索方式的分值变化过程,假设我…...
一、Prometheus架构
Prometheus 云原生十二要素是一套最佳实践和规范,旨在帮助开发人员更好地构建云原生应用 这十二个要素分别是: 单一职责独立部署无状态声明式API服务发现容错处理自适应算法自动化运维响应式编程通信协议服务注册与发现数据持久化一、Prometheus 是什么 Prometheus 是一个…...
蓝桥杯C组真题——巧克力
题目如下 思路 代码及解析如下 谢谢观看...
【大模型】大模型分类
大模型(Large Models)通常指参数量巨大、计算能力强大的机器学习模型,尤其在自然语言处理(NLP)、计算机视觉(CV)等领域表现突出。以下是大模型的常见分类方式: 1. 按应用领域分类 …...
WebUSB的常用API及案例
WebUSB API 允许网页与 USB 设备进行交互,但出于安全考虑,浏览器要求在调用 requestDevice 方法(用于请求用户选择一个 USB 设备并授予网页访问权限)时,必须是在处理用户手势(例如点击按钮)的过…...
在线研讨会 | 加速游戏和AI应用,全面认识Imagination DXTP GPU
近日,Imagination宣布推出 Imagination DXTP GPU IP,该产品重新定义了智能手机和其他功耗受限设备的图形和计算加速。它专为高效的效率而设计,能够提供运行AI、游戏和用户界面体验所需的性能,确保这些体验可以全天候流畅且持续地运…...
The Rust Programming Language 学习 (三)
所有权 所有权(系统)是 Rust 最为与众不同的特性,它让 Rust 无需垃圾回收器(garbage collector)即可保证内存安全。因此,理解 Rust 中所有权的运作方式非常重要。 这里是非常重非常重的一个知识点,这里一…...
【一个月备战蓝桥算法】递归与递推
字典序 在刷题和计算机科学领域,字典序(Lexicographical order)也称为词典序、字典顺序、字母序,是一种对序列元素进行排序的方式,它模仿了字典中单词的排序规则。下面从不同的数据类型来详细解释字典序: …...
【零基础到精通Java合集】第二十九集:SQL常用优化手段
课程标题:SQL常用优化手段——15分钟快速提升数据库性能 目标:掌握10+核心SQL优化技巧,解决慢查询、高负载等生产问题 0-1分钟:优化核心原则——减少数据扫描量 本质逻辑:通过索引、分页、过滤条件等手段,最小化磁盘I/O和内存计算。 反例:SELECT * FROM orders(全表扫…...
ArcGIS操作:07 绘制矢量shp面
1、点击目录 2、右侧显示目录 3、选择要存储的文件夹,新建shp 4、定义名称、要素类型、坐标系 5、点击开始编辑 6、点击创建要素 7、右侧选择图层、创建面 8、开始绘制,双击任意位置结束绘制...
如何远程访问svn中的URL
简介: 主要opencascade相关知识学习 格言: 万丈高楼平地起 要远程访问 SVN(Subversion)仓库中的 URL,通常需要以下步骤和注意事项: 1. 确认远程 SVN 服务器的访问协议 SVN 支持多种协议访问远程仓库&…...
归并排序:分治哲学的完美演绎与时空平衡的艺术
引言:跨越世纪的算法明珠 在计算机科学的璀璨星河中,归并排序犹如一颗恒久闪耀的明星。1945年,现代计算机之父冯诺伊曼在EDVAC计算机的研发过程中首次系统性地提出了这一算法,其精妙的分治思想不仅奠定了现代排序算法的理论基础&…...
【电控笔记z69】电机选型-机械特性
转矩特性 启动转矩 定义:指电机在启动瞬间所能提供的转矩。对于一些需要快速启动负载的设备,如起重机起升机构、电动汽车起步等,较大的启动转矩至关重要。影响因素:电机的类型、绕组参数、电源电压等都会影响启动转矩。例如,直流电机通过调节电枢电压和励磁电流可以在较大…...
Axure原型模板与元件库APP交互设计素材(附资料)
为了高效地进行APP和小程序的设计与开发,原型设计工具Axure凭借其强大的功能和灵活性,成为了众多产品经理和设计师的首选。本文将详细介绍Axure原型模板APP常用界面组件元件库、交互设计素材,以及多套涵盖电商、社区服务、娱乐休闲、农业农村…...
<网络> TCP协议
目录 TCP协议 与系统相关联 文件与套接字的关系 C语言的多态 谈谈可靠性 TCP协议格式 目的端口号 4位首部长度 16位窗口大小 序号与确认序号 32位序号 32位确认序号 标志位 TCP连接 三次握手 四次挥手 三次握手状态变化 四次挥手状态变化 流量控制 滑动窗口 拥塞控制 延迟应…...
自学微信小程序的第十三天
DAY13 1、使用map组件在页面中创建地图后,若想在JS文件中对地图进行控制,需要通过地图API来完成。先通过wx.createMapContext()方法创建MapContext(Map上下文)实例,然后通过该实例的相关方法来操作map组件。 const m…...
JAVA编程【jvm垃圾回收的差异】
jvm垃圾回收的差异 JVM(Java Virtual Machine)的垃圾回收(GC)机制是自动管理内存的一种方式,能够帮助开发者释放不再使用的内存,避免内存泄漏和溢出等问题。不同的垃圾回收器(GC)有…...
VBA信息获取与处理第五节:如何在单个工作表中查找某个给定值
《VBA信息获取与处理》教程(版权10178984)是我推出第六套教程,目前已经是第一版修订了。这套教程定位于最高级,是学完初级,中级后的教程。这部教程给大家讲解的内容有:跨应用程序信息获得、随机信息的利用、电子邮件的发送、VBA互…...
linux一些使用技巧
linux一些使用技巧 文件名称和路径的提取切换用户执行当前脚本一行演示单引号与双引号的使用curl命令仅输出响应头信息,不输出body体文件名称和路径的提取 文件路径为 /tmp/tkgup/test.sh 方式获取文件名获取文件路径获取文件全路径方式一basename ${file}dirname ${file}real…...
ubuntu20.04 安装离线版docker-20.10.0
1. 安装步骤 步骤一:官网下载 docker 安装包 wget https://download.docker.com/linux/static/stable/x86_64/docker-20.10.0.tgz步骤二:解压安装包; tar -zxvf docker-20.10.0.tgz 步骤三:将解压之后的docker文件移到 /usr/bin目录下; c…...
K8s 1.27.1 实战系列(一)准备工作
一、准备服务器 主机IP 操作系统计算资源 说明 192.168.202.23 CentOS74核8G内存50G硬盘 k8s-master 192.168.202.24 CentOS74核8G内存50G硬盘 k8s-node1 192.168.202.25 CentOS74核8G内存50G硬盘 k8s-node2 二、准备环境(所有节点) 1、关闭防火墙&…...
【推荐算法】python游戏数据分析可视化推荐系统(完整系统源码+数据库+开发笔记+详细部署教程)✅
目录 一、项目背景 二、项目拟解决问题 (1)数据价值断层 (2)用户画像模糊 (3)推荐策略单一 (4)决策可视化缺失 三、研究目的 (1)轻量化服务架构验证 …...
