微信小程序:渲染流程、生命周期和触发顺序

微信小程序:渲染流程、生命周期和触发顺序,第1张

程序的生命周期分为 应用生命周期 、 页面生命槐颂周期

App() 必须在 app.js 中调用,必须调用且 只能调用一次 ,app.js中定义了一些应用的生命周期函数

(1)onLaunch: 初始化小程序时触发,全局只触发一次

(2)onShow: 小程序初始化完成或用户从后台切换到前台显示时触发

(3)onHide: 用户从前台切换到后台隐藏时触发

(4)onError: 小程序发生脚本橘胡错误,或者 api 调用失败时,会触发 onError 并带上错误信息

后台:点击左上角关闭,或者按了设备 Home 键离开微信,并没有直接销毁,而是进入后台

前台:再次进入微信或再次打开小程序,相当于从后台进入前台。

官方介绍 https://developers.weixin.qq.com/miniprogram/dev/reference/api/App.html

js文件中定义了一些页面生命周期函数,下面简述下这些生命周期函数的方法作用

(1)onLoad:首次进入页面加载时触发,可以在 onLoad 的参数中获取打开当前页面路径中的参数。

(2)onShow:加载完成后、后台切到前台或重新进入页面时触发

(3)onReady:页面首次渲染完成时触发

(4)onHide:从前台切到铅伍郑后台或进入其他页面触发

(5)onUnload:页面卸载时触发

官方介绍 https://developers.weixin.qq.com/miniprogram/dev/reference/api/Page.html

通过console.log验证它们的触发顺序

以上是对生命周期粗略的认识,如有不足请指正~

参考链接 https://www.jianshu.com/p/2e48f2468d5f

小程序的wxs功能可以让wsmxl可以调用和编写js,基本上wxs和JS无关系,只是语法形式很相似。

如下写了两个关于时间的函数,并将它们导出,

<wxs module="敬桥昌m1">亮扒

var getMax = function(flightDate) {

    var now = getDate().getDate()

    var flDate = getDate(flightDate).getDate()

    if( now <flDate ){

      return '+1'

    }else{

      return ''

    }

}

var formartTime = function(flightDate,format){

  if(flightDate){

    var realDate = getDate(flightDate)

    function timeFormat(num) {

      return num <10 ? '0' + num : num

    }

    var date = {

      "Y": timeFormat(realDate.getFullYear()),

      "M": timeFormat(realDate.getMonth() + 1),

      "d": timeFormat(realDate.getDate()),

      "h": timeFormat(realDate.getHours()),

      "m": timeFormat(realDate.getMinutes()),

      "s": timeFormat(realDate.getSeconds()),

      "q": Math.floor((realDate.getMonth() + 3) / 3),

      "S": realDate.getMilliseconds(),

    }

    if (!format) {

      format = "yyyy-MM-dd hh:mm:ss"

    }

    if( format == 'hh:mm' ){

        return date.h+':'+date.m

    }else{

        return date.h+':'+date.m

    }

  }else{

    return false

  }

}

module.exports.getMax = getMax

module.exports.formartTime = formartTime

</消行wxs>

可在页面添加如下使用:

m1.formartTime()  m1.getMax()

1、首先通过快捷方式打开微信小程序开发工具,在index.wxml文件中,插入view标签,然后使用wx:for循环,wx:if和wx:else条件渲染,生成不同的组件基睁。

2、在index.js文件中,data对象中定义数组变量items并初始化。

3、保存代码并查看左侧模拟器,结果发现生成的全部是单选按钮。

4、这时检查代码发现,使用wx:if条件渲染,需要使用仔握item.id%2==0。

5、最后保存代码并查看模拟器,可以发现单选按钮和复选框念锋庆间隔显示。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12341430.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存