【微信小程序】运行机制和更新机制

🍒观众老爷们好呀,牛牛又更文了,上文我们对部分比较常用的组件进行了讲解,作为开发者,我们还需要对小程序的运行机制和更新机制做一定的了解,那问题来了,你对它们了解多少呢?
🍒今天牛牛就带大家测一测,不了解的还不笔记做起来!

文章目录

    • 一,运行机制
      • 1.1 小程序的启动
      • 1.2 小程序前后台
      • 1.3 挂起状态
      • 1.4 小程序销毁事件
    • 二,更新机制
      • 2.1 启动时同步更新
      • 2.2 启动时异步更新
      • 2.3 开发者手动触发
    • 三,生命周期

一,运行机制

第一个说明的是小程序的运行机制,小程序从启动到最终被销毁,其实会有很多不同的步骤,小程序会经历多种状态,大致的运行机制如下图所示。
在这里插入图片描述
接下来我们开始详细的步骤讲解

1.1 小程序的启动

看上图,我们知道,小程序首先会有一个冷启动,简单讲解就是用户首次打开小程序,或者小程序经过一定时间自动销毁后被用户再次打开,这个时候,小程序需要重新加载代码,重新加载启动。

这时候可能有小伙伴会问啦,那如果还没销毁就再次启动小程序呢?这个时候就叫做热启动啦,平时使用小程序的时候,我们会发现,关闭小程序后不久重新打开,加载的速度比前者快上不少,这就是因为小程序未被销毁,是从后台状态进入前台状态,这个过程我们叫做热启动,也可以说切前台。

1.2 小程序前后台

小程序完成加载之后,会有两种状态,分别是前台状态后台状态

  • 小程序启动后,在界面展示出来的时候,该小程序就处于前台状态
  • 而当我们关闭小程序时,在一定时间内,小程序并没有真正关闭也就是销毁,而是进入所说的后台状态,后台状态下小程序依然在运行,只是部分API的使用会受到限制。这里的操作就是前图中的切后台。
  • 正常情况下,后台状态的时间不会持续很长时间,一小段时间后就会开启挂起事件,进入挂起状态(后文解释)。
  • 在销毁前,用户再次点击小程序打开,小程序就会从后台状态挂起状态重新进入前台状态这也就是我们前边说到的热启动

1.3 挂起状态

小程序在后台状态呆很短的时间后,就会切换到挂起状态,在该状态下,微信会停止该小程序JS线程的执行,小程序的内容状态会被暂时保留,事件、回调等等在小程序重新进入前台状态时才会触发。

小tip:

  • 后台并不会停止JS线程的执行,如果小程序开启了后台音乐播放地理位置等功能时,小程序不会从后台切入挂起,也就是小程序可以持续运行

1.4 小程序销毁事件

最后一个就是当挂起状态持续过久(目前是三十分钟),为了减轻资源紧张,这时候,小程序就会被销毁啦。

还有一种情况,当小程序占用系统资源过多,也会被系统销毁或者被微信客户端主动回收。

在开发中,我们可以用wx.onMemoryWarning监听内存告警事件,设置内存清理。

二,更新机制

我们知道,微信客户端会在本地缓存中缓存小程序的代码,而开发者在管理后台中会不定时发布更新的新版本小程序,那么微信客户端是怎么知道是否有新版本的呢?

其实微信客户端会有若干个时机取检查本地缓存,如果有新版本,那就进行小程序代码包的更新,但如果恰巧发布新版本后没有经过这些时机就打开小程序,那打开可能还会是旧版本的小程序。

下面牛牛来列举这些检查更新的时机

2.1 启动时同步更新

同步更新会影响到小程序的启动耗时,启动时并不一定会发生同步更新,以下两种情况,会在启动小程序时同步更新。

  • 定期检查发现新版本
    微信在运行的时候,会定期检查最近使用小程序是否具有新版本,并在下一次启动小程序时设置是否同步更新

  • 用户长时间未使用
    长时间未使用小程序,微信客户端为了小程序版本迭代正常,会对这些小程序设置启动时同步更新。

2.2 启动时异步更新

每次小程序冷启动时,都会有异步检查是否有新版本的操作,如果发现新版本,会将新版本代码进行异步下载,而不影响小程序的运行,不过这也会导致,如果启动后仍然是旧版本,只有下次启动,才会打开新版本的小程序。

2.3 开发者手动触发

微信提供了一个APIwx.getUpdateManager,可以在有新版本时提示用户重启小程序更新新版本

三,生命周期

最后就让我们以生命周期作为今天的结尾吧。

  • 生命周期可以分为程序和页面两部分,对于程序,我们首次启动小程序时,会触发onLaunch方法,当我们的小程序初始化完成后,便会触发onShow方法,页面加载并显示,此时触发显示页面的onLoadonShow方法,成功显示页面。

  • 首次显示页面,还会触发页面的onReady方法,对页面元素进行渲染,注意,该方法,一个页面只会调用一次。

  • 当小程序切入后台时,注意,小程序会先触发页面的onHide方法,将页面隐藏,再触发程序的onHide方法

  • 而当小程序从后台切入前台时,小程序会先触发程序的onShow方法,再触发页面的onShow方法,将页面显示。

这里放上一张网上的图片便于大家理解
在这里插入图片描述
本文到这里就结束啦,如果觉得对您有帮助的话,可以关注一下牛牛后续的更新,感谢您的支持!
债见~

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

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

相关文章

小程序进入页面控制台报wx.openChannelsUserProfile is not a function

今天拉取代码发现有冲突,内容还挺多,懒得修改,直接删掉重新下载. 冲突是解决了,进入首页发现报wx.openChannelsUserProfile is not a function,小程序是能正常使用的. 网友大佬说是调试库版本低于2.10.x 地址 :https://blog.csdn.net/fqfq123456/article/details/119633765 我…

hb运行到微信小程序出现报错:[微信小程序开发者工具] ? Enable IDE Service (y/N) 

背景: 换了台电脑,发现hb运行到微信小程序的时候出错了 18:09:17.800 [微信小程序开发者工具] ? Enable IDE Service (y/N) [27D[27C 18:09:17.803 [微信小程序开发者工具] - initialize 18:09:17.803 [微信小程序开发者工具] 18:09:17.807 [微信小程…

uniapp微信小程序运行成功但是没调用微信开发者工具

先看运行里面的运行设置,开发者本地的地址是否是好的 然后看微信开发者工具里面的设置,找到安全设置,打开服务端口,这样工具就可以被命令行和http调用了

从uni-app运行到微信开发者工具小程序后没有自动打开项目的原因

今天从uni-app运行程序到微信开发者工具却没有自动将项目进行打开的原因: 是uni-app端的微信小程序的AppID与微信开发者工具的不一致导致的没有打开。 所以我们一定要两边的AppID是一致的才行。 去网页查看自己的AppID 微信开发工具的AppID 打开我们文件里面的ma…

微信小程序之停止录音

今日继续在第二大学远程实习,上次分享了微信小程序的录音,录音有开始也肯定有停止,分享一下停止录音的实现。 在我们实际应用开发中可能还会遇到小程序视频、录音、直播冲突的情况,或者录音过程中来了电话被中断录音等情况&#…

微信小程序之开发遇到 does not have a method “xxxx“ to handle event “tap“ 问题的解决方案【已解决】

今天在开发一个小功能,copy了之前写的代码,但是在实现功能时,出现了如下问题: 先在这简单总结一下解决方案: 在调用方法时,在" "中前后多加了空格;在 js 中没有定义该方法&#xff1…

运行微信小程序出现的问题

1.问题一:用Hbuilder工具运行后,能跳到微信开发者工具界面,但是小程序项目打不开。 解决:第一步检查以下这些插件是否安装好。 第二布检查manifest.json的微信小程序配置的AppID是否配置好。 第三步检查服务端口是否打开了。 …

微信小程序运行及更新机制

微信小程序运行及更新机制 1、微信小程序运行机制1.1 前台和后台1.2 小程序启动:冷启动和热启动1.3 小程序销毁 2、微信小程序更新机制2.1 启动时同步更新定期检查发现版本更新用户长时间未使用小程序 2.2 启动时异步更新开发者手动触发更新 2.3 小程序管理后台的相…

微信小程序之---使用微信开发者工具调试小程序 debug 失效 以及 console.log 无法输出

项目场景: 使用 HbuilderX 开发微信小程序,在调试的过程中,使用了 debug 以及 console.log ,在 H5 中输出测试都是可以的,但是运行到微信开发者工具之后, console.log 无法生效,在查阅相关解决办法之后,都没有解决 问题描述 在此之前有尝试过一些解决方案,如清除缓…

什么才是好的商业计划书呢?

不同行业的商业计划书有所不同,同一行业由于项目的差异,使得商业计划书也有所不同。什么才是好的商业计划书呢?一言以概之,能让投资者心服口服拿出钱的商业计划书就是好的商业计划书。虽然商业计划书的写法有多种,格式…

一份好的商业计划书该怎么写

一、商业计划书是创业者找VC/PE的敲门砖 •据统计投资人平均每天收到50-100份BP,而只有5-8份会受到重视 •投资人阅读每份商业计划书平均时间为3分44秒 •商业计划书平均长度19.2页,建议不超过20页 •商业计划书撰写建议使用PPT(节省投资人时…

商业计划书中该如何做产品介绍?

在商业计划书中,投资人关心的问题之一就是,风险企业的产品、技术或服务能否以及在多大程度上解决现实生活中的问题,或者,风险企业的服务及产品能否帮助顾客节约开支,增加收入。因此,产品介绍是商业计划书中…

扬帆优配|翻倍牛股“高台跳水”,一度跌停,啥情况

2月23日上午,A股商场窄幅震荡,上证指数上午收盘涨0.07%,煤炭、电力设备等板块领涨。 总的来看,A股商场上午整体体现安静,不过仍有个股大幅动摇,比如前期翻倍热门股汉王科技盘中“高台跳水”,一…

记一次post请求参数太长导致的400报错

背景:spring boot2.1.1 vue2.6.11 iview3.3.0 axios0.18.1 这个接口是接收前台图文编辑器的内容,插入数据库,当接收图文内容的字段过长时,就抛出400 后台代码: 前台请求: 报错信息: 网上…

post 参数过多导致url过长,请求413 HEAD FULL

1.问题描述 java用apache httpclient请求目标应用,目标应用使用jettyspringMvc提供服务,请求的参数使用RequestParam方式接收,故用aA&bB&cC把请求参数直接追加到url方式调用目标应用,当参数过多时候,发现服务起…

post 400 (Bad Request)异常怎么排查参数问题

问题描述: 用ajax请求时报post 400 (Bad Request)的异常,前台js参数JSON.stringify(data),后台controller 中RequestBody XX xx(javabean)接收参数。 通常发生400时,即使在后台方法上设置断点,但因400是参数由json转换成Javabean…

微信小程序获取手机号47001 data format error hint的完美解答(restTemplate发送post请求)

发现问题 这几天正在搞微信小程序获取手机号功能开发,发现发送post请求接口时候,接口返回如下错误: {"errcode": 47001,"errmsg": "data format error hint: [******] rid: ******" } post请求的url为&…

搭建个人专属的API中转站,解决本地OpenAI接口调用困扰

今天仅仅只是站在开发者学习交流的角度来介绍一下,我们在日常开发基于LLM的AI应用时遇到的各种瓶颈,毕竟开发出一个优质的应用,舒适的环境和体验还是比较重要的。话不多说,进入正题。 一、搭建OpenAI中转站 如何搭建个人专属的A…

哈佛医学院退出US News排名,此前已有耶鲁哈佛等顶尖法学院「退群」

詹士 发自 凹非寺量子位 | 公众号 QbitAI 哈佛医学院也宣布退出U.S. News排名了! 在最新发布的声明中,学院院长对外表示,他们将不再向评选机构USNWR提交数据,以支持他们“最佳医学院”的调研排名。 事实上,哈佛医学院在…

港联证券|科技股热度扩散 6G概念受追捧

昨日,科技股热度继续分散,6G概念股高开高走。截至收盘,Choice的6G概念指数全体大涨3.64%。A股方面,信科移动20%起伏涨停,股价创前史新高;本川智能上涨近15%,中兴通讯、创远信科、金信诺等涨超4%…