小程序的运行机制、更新机制、生命周期介绍保姆级教程全解

一、小程序运行机制

在这里插入图片描述

1. 小程序冷启动

	小程序启动可以分为两种情况,一种是冷启动,一种是热启动- 冷启动:如果用户首次打开,或小程序销毁后被用户再次打开,此时小程序需要重新加载启动- 热启动:如果用户已经打开过某小程序,然后再一定时间内再次打开该小程序,此时小程序并未被销毁,只是从后台状态进入前台状态

2. 前台和后台状态

小程序启动后,界面被展示给用户,此时小程序处于【前台】状态。
当用户【关闭】小程序时(通过以下图片形式 ),并没有真正被关闭,而是进入了【后台】状态,
当用户再次进入微信并打开小程序,小程序优惠重新进入【前台】状态

在这里插入图片描述

3. 切前台和切后台

小程序启动后,界面被展示给用户,此时小程序处于【前台】状态。
当用户【关闭】小程序时,小程序并没有真正被关闭,而是进入了【后台】状态,当用户再次进入微信并打开
小程序,小程序又会重新进入【前台】状态

4. 挂起

小程序进入【后台】状态一段时间后(5秒),微信停止小程序JS线程执行,小程序进入【挂起】状态,
当开发者使用了后台播放音乐、后台地理位置等能力时,小程序可以再后台持续运行,不会进入到挂起状态

5. 销毁

如果用户很久没有使用小程序,或者系统资源紧张,小程序会被销毁,即完全终止运行。
当小程序进入后台并被【挂起】后,如果很长时间(目前时30分钟)都未再次进入前台,小程序会被销毁
当小程序占用系统资源过高,可能会被系统销毁或被微信客户端主动回收。

二、小程序更新机制

	在访问小程序时,微信会将小程序代码包缓存到本地。开发者在发布了新的小程序版本后,微信客户端会检查本地缓存的小程序有没有新版本,并进行小程序代码包的更新。小程序的更新机制有两种:启动时同步更新和启动时异步更新。

1. 启动时同步更新

	微信运行时,会定期检查最近使用的小程序是否有更新,如果有更新,下次小程序启动时会同步进行更新,更新到最新版本后再次打开小程序,如果用户长时间未使用小程序时,会强制同步检查版本更新。

2. 启动时异步更新

在启动前没有发现更新,小程序每次 冷启动 时,都会异步检查是否有更新版本。如果发现有新
版本,将会异步下载新版本的代码包,将新版本的小程序在下一次冷启动进行使用,当前访问
使用的依然时本地的旧版本代码

3. 在启动异步更新的情况下,如果开发者希望立即进行版本更新,可以使用 wx.getUpdateManager API 进行处理。在有新版本时提示用户启动小程序更新版本。

// app.js
App({// 小程序的钩子函数,这个钩子函数在冷启动时会执行到// 当小程序冷启动时,会自动向微信后台请求新版本的信息,如果有新版本,会立即进行下载onLaunch(){// 使用 wx.getUpdateManager 方法监听下载的状态const updataManager=wx.getUpdateManager()// 当下载完成新版本以后,会触发 onUpdateReady 回调函数updataManager.onUpdateReady(function(){// 在回调函数中给用户提示wx.showModal({title: '更新提示',content: '新版本已经准备好,是否重新启用',success(res){if (res.confirm) {// 强制当前小程序使用新版本并且会重启当前小程序updataManager.applyUpdate()}}})})}
})

三、小程序生命周期

1. 小程序生命周期介绍

应用生命周期是指应用程序进程从创建到消亡的整个过程
小程序的生命周期指的是 小程序从启动到销毁的整个过程。
一个小程序完整的生命周期由 应用生命周期、页面生命周期和组件生命周期 三部分来组成。
小程序生命周期伴随着一些函数,这些函数由小程序框架本身提供,被称为生命周期函数,生命周期函数会
按照顺序一次自动触发调用。
帮助程序员在特定的时机执行特定的操作,辅助程序员完成一些比较复杂的逻辑。

2. 应用生命周期

应用生命周期通常是指一个程序从 启动--->运行--->销毁的整个过程
应用生命周期伴随着一些函数,我们称为 应用生命周期函数,应用生命周期函数需要 在 app.js文件的App()
方法中进行定义,App()方法必须在app.js中进行调用,主要用来注册小程序。
应用生命周期函数由 onLaunch 、onShow、onHide 三个函数组成。

在这里插入图片描述

3. 页面生命周期

页面生命周期就是小程序页面从加载--->运行--->销毁的整个过程
页面生命周期函数需要在Page()方法进行定义

在这里插入图片描述
注意:onLoad 和哦那Ready函数一个页面只会调用一次

Page({onLoad: function (options) {console.log('onLoad 页面创建的时候执行')},onReady: function () {console.log('onReady 页面初次渲染完成时触发,代表页面已经准备妥当,可以和视图层进行交互')},onShow: function () {console.log('onShow 页面在前台展示的时候')},onHide: function () {console.log('onHide 当前页面页面隐藏')},onUnload: function () {console.log('onUnload 当前页面页面被销毁时触发')}
})

4.生命周期两个细节

  • tabBar 页面之间相互切换,页面不会被销毁
  • 点击左上角,返回上一个页面,会销毁当前页面
    在这里插入图片描述

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

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

相关文章

HSP_12章 Python面向对象编程oop_多态

文章目录 P128 多态问题的引出P129 多态细节和使用1. 多态介绍&特别说明2. 多态的好处3. 特别说明: Python多态的特点4. 使用多态的机制来解决主人喂食物的问题 P128 多态问题的引出 先看一个问题 # 说明: 先试用传统的方式完成 class Food:name Nonedef __init__(self,…

4.Android逆向协议-详解二次打包失败解决方案

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 内容参考于:微尘网校 上一个内容:3.Android逆向协议-APP反反编译及回编译 工具下载: 链接:https://pan.baidu.…

【MyBatis】 - 自定义TypeHandler-数组

在Java中,如果你使用的是MyBatis并需要为String数组自定义TypeHandler,可以按照以下步骤进行操作。TypeHandler用于自定义对象与数据库字段之间的转换。 步骤一:创建自定义的TypeHandler 首先,你需要创建一个自定义的TypeHandle…

#笔记# 写给自己用的小爬虫

最近完成了一个文旅行业信息聚合的小应用,实现仅从一个入口了解全行业的信息动态,不用一个一个翻看各网站,节省了不少检索时间。 一、基本思路 明确数据来源。基于前述目标,确定数据源为文化和旅游部管理部门官网,比…

STM32中断

目录 stm32中断原理标准库高低电平使LED亮灭灯采用串口中断方式做串口通信 stm32中断原理 在STM32微控制器中,中断是一种重要的事件驱动机制,用于处理实时事件而无需持续轮询。中断在处理外部事件(如按键输入、定时器溢出等)时非…

【办公类-21-18】20240701 养老护理员初级选择题488,制作PyQt5图形界面GUI

背景需求: 6月16日育婴师高级考完了。运气好,抽到的是”护理患腹泻的幼儿”,“晨检与家长沟通”,“4个月婴儿喂蛋黄”,“21个月食谱”,都是我背过的题目(没有抽到感统) 于是一放假&…

【C语言】解决C语言报错:Invalid Pointer

文章目录 简介什么是Invalid PointerInvalid Pointer的常见原因如何检测和调试Invalid Pointer解决Invalid Pointer的最佳实践详细实例解析示例1:未初始化的指针示例2:已释放的指针示例3:返回局部变量的指针示例4:野指针 进一步阅…

three.js获取深度图

在Three.js中,获取深度图(Depth Map)通常涉及几个步骤。深度图是一个图像,其中每个像素的值表示从摄像机到场景中相应点的距离。以下是如何在Three.js中获取深度图的基本步骤: 设置WebGLRenderer:确保你的T…

Android裁剪内核后编译报错compatibility matrix

【问题描述】: 优化开机速度,裁剪kernel,注释掉模型模块后如:# CONFIG_HID_SONY is not set,出现编译报错。 checkvintf E 07-01 16:32:02 160 160 check_vintf.cpp:620] files are incompatible: Runtime info a…

《化学工程与装备》是什么级别的期刊?是正规期刊吗?能评职称吗?

​问题解答 问:《化学工程与装备》是不是核心期刊? 答:不是,是知网收录的第一批认定学术期刊。 问:《化学工程与装备》级别? 答:省级。主管单位:福建石油化工集团有限责任公司 …

昇思25天学习打卡营第6天|网络构建

网络构建 概念模型模型参数 概念 神经网络模型是由神经网络层和Tensor操作构成的,mindspore.nn提供了常见神经网络层的实现,在MindSpore中,Cell类是构建所有网络的基类,也是网络的基本单元。一个神经网络模型表示为一个Cell&…

技术革新:如何用数据中台实现数字化转型

作为程序员,我们总是对技术如何改变企业运作充满好奇。今天,我们将深入探讨森马集团如何利用数据中台技术,实现从传统数据分析到数字化转型的华丽转身。 1. 技术背景:森马集团的数字化挑战 森马集团,一个在服饰行业占…

[单master节点k8s部署]8.pod健康探测

k8s默认的健康检查机制是,每个容器都有一个监控进程,如果进程退出时返回码非零,则认为容器发生故障。 存活探测 监测pod是否处于运行状态,当liveness probe探测失败的时候,根据重启策略判断是否需要重启。适用于需要…

【Win测试】窗口捕获的学习笔记

2 辨析笔记 2.1 mss:捕获屏幕可见区域,不适合捕获后台应用 Claude-3.5-Sonnet: MSS库可以用来捕获屏幕上可见的内容;然而,如果游戏窗口被其他窗口完全遮挡或最小化,MSS将无法捕获到被遮挡的游戏窗口内容,而…

天津惠灵顿:从心,致逐梦康桥|在这所天津国际学校从容不迫中走近梦想

在刚刚落下帷幕的申请季中,来自惠灵顿天津校区的Herman,陆续收到了剑桥大学、帝国理工学院、纽约大学、瓦萨学院等10余封录取通知书。面对纷至沓来的名校肯定,经历了短暂的尘埃落定的喜悦,Herman很快恢复了往日里的泰然自若。在他…

cv::Mat类的矩阵内容输出的各种格式的例子

操作系统&#xff1a;ubuntu22.04OpenCV版本&#xff1a;OpenCV4.9IDE:Visual Studio Code编程语言&#xff1a;C11 功能描述 我们可以这样使用&#xff1a;cv::Mat M(…); cout << M;&#xff0c;直接将矩阵内容输出到控制台。 输出格式支持多种风格&#xff0c;包括O…

第5章:Electron加载与显示内容(2)

5.4 加载和显示不同类型的资源 Electron 支持加载和显示多种类型的资源&#xff0c;包括图片、视频和其他静态文件。 5.4.1 加载图片的示例代码 index.html&#xff1a; <!DOCTYPE html> <html> <head><title>Load Image</title> </head&…

字符串常量池StringTable

String s1 "a"; 从常量池中取符号a->运行时常量池 ->"a"放入字符串常量池 -> 给s1 String s2 "b"; String s3 s1s2; 创建 new StringBuilder().append("a").append("b").toString() String s4 "a"&q…

鸿蒙使用 @Builder扩展出来的布局数据更新没法更新UI

由于业务的复杂&#xff0c;所以我们把相关UI抽离出来。但是数据变化了&#xff0c;没法更新UI Builder MyGridLayout() { } 通过日志打印发现数据的确是更新了&#xff0c;但是UI就没没办法&#xff0c;如何解决呢 Entry Component struct Page35 {// State sArray: bool…

【ajax实战09】内容管理页面——删除功能

本文章目标&#xff1a;点击删除图标实现对应数据删除 实现步骤如下&#xff1a; 一&#xff1a;将服务器端获取数据中数据id值绑定到删除图标&#xff08;重点&#xff09; 即在渲染时&#xff0c;利用自定义属性&#xff0c;为td设置id值 <td data-id "${ele.id}…