位置: IT常识 - 正文

小程序生命周期(小程序生命周期钩子)

编辑:rootadmin
小程序生命周期

推荐整理分享小程序生命周期(小程序生命周期钩子),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:小程序生命周期和页面生命周期,小程序生命周期和页面生命周期,小程序生命周期和页面生命周期,微信小程序生命周期,小程序生命周期和页面生命周期,小程序生命周期有哪些函数,作用是什么?,小程序生命周期函数执行顺序,微信小程序生命周期,内容如对您有帮助,希望把文章链接给更多的朋友!

小程序的生命周期说白了就是指程序从创建、到开始、暂停、唤起、停止、卸载的过程。

我们大概从三个角度看一下小程序的生命周期。

(1):应用生命周期

(2):页面生命周期

(3):组件生命周期

应用生命周期

用户首次打开小程序,触发 onLaunch(全局只触发一次)。

小程序初始化完成后,触发onShow方法,监听小程序显示。

小程序从前台进入后台,触发 onHide方法。

小程序从后台进入前台显示,触发 onShow方法。

小程序后台运行一定时间,或系统资源占用过高,会被销毁。

前台、后台定义: 当用户点击左上角关闭,或者按了设备 Home 键离开微信,小程序并没有直接销毁,而是进入了后台;当再次进入微信或再次打开小程序,又会从后台进入前台。

在整理本文资料的时候,有点不解,为什么不把小程序监听『销毁』方法开放给开发者,我猜测是因为IOS系统限制『按下Home键时,app从活动状态转入后台,会被挂起』;微信也不例外,只要运行一段时间或把微信客户端进程杀掉,就无法通知小程序应用被销毁。

页面生命周期

小程序注册完成后,加载页面,触发onLoad方法。

页面载入后触发onShow方法,显示页面。

首次显示页面,会触发onReady方法,渲染页面元素和样式,一个页面只会调用一次。

当小程序后台运行或跳转到其他页面时,触发onHide方法。

当小程序有后台进入到前台运行或重新进入页面时,触发onShow方法。

当使用重定向方法wx.redirectTo(OBJECT)或关闭当前页返回上一页wx.navigateBack(),触发onUnload

组件生命周期

组件生命周期,官网介绍的原话是:指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发。大概意思就是,我们知道生命周期指的是从加载到销毁这个过程,在这个过程中可以分为好多阶段,比如,创建阶段,挂载阶段,销毁阶段等等,在每个阶段程序内部都会向外抛出一个 回调函数,这个回调函数,就是生命周期; 组件生命周期在官网的介绍地址如下:组件生命周期

小程序生命周期(小程序生命周期钩子)

created:在组件实例刚刚被创建时执行,在这个阶段由于组件刚刚被创建,this.setData这些函数是不会生效的,在这个生命周期内,我们只可以获取一些基本的值以及数据上的做处理,跟页面渲染相关的内容不能在这个生命周期实现;

attached:组件初始化完毕并且挂载到页面上之后触发,如果熟悉vue的话,和vue的mounted比较像,这个阶段才是我们一般做初始化的阶段,并且在这个阶段data也被初始化为组件的值;

detached:在组件实例被从页面节点树移除时执行,简单的说,就是这个 **组件被销毁 **的时候会被执行,这个使用的还是非常频繁的

ready:在组件在视图层布局完成后执行,简单的说,就是组件被挂载到页面上,并且页面渲染完毕后触发;这个生命周期我们一般处理一些跟视图操作相关的内容;

moved:在组件实例被移动到节点树另一个位置时执行

整体周期(1)打开页面的情况

首先,前一个页面隐藏,在加载下一个页面之前,需要先初始化新页面的组件。页面首次渲染之后,会触发组件的ready,最后触发的是页面的onReady,如下图:

从PageA打开pageB时的生命周期顺序

(2)离开页面的情况

离开当前页面时,首先触发当前页面的卸载onUnload,接着是组件离开节点树的detached。最后显示之前的页面,触发onShow。如下图:

从PageB返回到PageA的生命周期顺序

(3)打开App的情况

App、Page与Component生命周期运行顺序,先从App加载然后再加载Page,在加载Page之前会先初始化该页面所用的所有组件,之后才触发页面的onLoad生命周期,如下图:

打开App时的生命周期顺序

(4)切换到后台

切换到后台时,小程序和页面并没有卸载,只会触发隐藏。先触发页面的onHide,接着是App的onHide。如下图:

切换到后台时的生命周期顺序

(5)切换到前台

切换到后台时,小程序会先触发onShow,之后才是页面的onShow。如下图:

切换到前台时的生命周期顺序

总结

1. 打开小程序:

(App)onLaunch --> (App)onShow --> (Pages)onLoad --> (Pages)onShow --> (pages)onReady

2. 进入下一个页面:

(Pages)onHide --> (Next)onLoad --> (Next)onShow --> (Next)onReady

3. 返回上一个页面:

(curr)onUnload --> (pre)onShow

4. 离开小程序:

(App)onHide

5. 再次进入:

小程序未销毁 --> (App)onShow(执行上面的顺序),小程序被销毁,(App)onLaunch重新开始执行. 整体周期来源:微信小程序生命周期

本文链接地址:https://www.jiuchutong.com/zhishi/297639.html 转载请保留说明!

上一篇:vue3中的配置代理(vue3.0配置)

下一篇:vue项目使用定时器每隔几秒运行一次某方法(vue定时调用方法)

  • 什么是差额税金
  • 已交税金是什么类
  • 实收资本库存现金凭证怎么开
  • 货没出,发票先开
  • 间接持股比例怎么
  • 银行回单日期晚于做账日期
  • 银行开户登记号在哪看
  • 长期借款账务处理会计分录例题
  • 固定资产清理期末可以有余额吗
  • 结汇收益怎么算
  • 机械租赁增值税税率2022年
  • 2020年个体工商户税收政策超出额度怎么征收
  • 客户充值
  • 捐款怎样抵扣个税
  • 设备安装和设备出售的税率一样吗
  • 转让土地使用权 简易征收
  • 目前建筑里面税金总共包括几部分
  • 工资薪金税前扣除比例
  • 购进货物作为优秀员工的奖励是否可以进项抵扣?
  • 政府规费可以做进项抵扣吗?
  • 案例分析:如何缓解幼儿在幼儿园的焦虑情绪
  • 最新事业单位固定资产折旧规定
  • 支票只能同城吗
  • 外贸企业出口收入确定
  • 拿回费用票普票忘记入账怎么办?
  • 房地产企业的样板房,装修款如何缴纳增值税
  • 其他应付款下的固定资产怎么报废
  • 华为手机哪一款好用性价比高
  • 电脑dwm.exe是什么
  • 增值税发票选择确认平台注意事项
  • 最贵的苹果4
  • 处置设备影响的净损益
  • html怎么引入图片
  • 股权转让企业所得税怎么算
  • 如何快速使用验证码
  • 差旅费住宿费专票抵扣联贴在哪里
  • 西安微信公众号开发
  • 残保金申报操作流程
  • 现金折扣账务处理
  • ubuntu系统日志配置文件
  • 小规模纳税人征收方式
  • 垃圾处置费的收费标准
  • asp和asp net
  • 织梦怎么用模板建站
  • 登记会计账簿的实训总结
  • 装修及室内设计学什么
  • 银行贷款可以置换险资吗
  • 土地利息可以作为土增扣除吗
  • 未分配利润实际没有钱分配是什么原因
  • 私车公用必须是公司员工的车吗?
  • 城市维护建设税属于中央还是地方
  • 房地产公司退房款怎么做账
  • 补缴以前年度企业所得税如何做账
  • 事业单位利息收入
  • 应付职工薪酬要设二级科目吗
  • 计提工资的会计账务处理
  • 持有至到期投资是债权投资吗
  • 期间费用是啥
  • 企业会计档案由谁保管
  • 工业会计科目有哪些
  • mac显示所有窗口的快捷键
  • win8系统如何分区
  • linux命令ls-l
  • linux shell 常用命令大全
  • win10用360卫士好吗
  • 如何装win8.1
  • tar命令参数详解
  • cocos2dx游戏有哪些
  • cocos2dx4.0教程
  • 电脑自动检测硬盘怎么取消
  • 谈谈网页设计中的内容
  • 关于echo的名字
  • python介绍的主要内容
  • unityai寻路
  • node.js web
  • nodejss
  • 安卓手机照片压缩
  • javascript简明教程
  • 国有土地使用权出让和转让条例
  • 税控盘操作指南
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设