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
小程序的生命周期函数是一组函数,在小程序生命周期内按约定的顺序被调用。简单来说孙穗,生命周期函数就是在小程序的运行过程中自动执行的某些函数。这些函数在不同时期扮演不同的角色,比如在小程序启动时进行初始化,页面渲染时获取数据,页面切换时暂停和恢复等。小程序的生命周期函数有以下几个:1. `onLaunch`: 小程序初始化加载时的钩子函数,全局只触发一次。可以在此函数中获取小程序的启动参数、从缓存中获取数据等。
2. `onShow`: 小程序启动或从后台进入前台时触发。可以在此函数中获取小程序的路径参数、检查用户是否宴凯拿登录等。
3. `onHide`: 小程序从前台进入后台时触发。可以在此函数中暂停正在播放的音乐、记录页面状态等。
4. `onError`: 小程序发生错误时触发。可以在此函数中将报错信息发送给晌搭开发者,以便定位问题。
5. `onPageNotFound`: 小程序页面不存在时触发。可以在此函数中提示用户该页面不存在,或者自动跳转到其他页面。
除了以上五个生命周期函数,小程序中还有一些页面级别的生命周期函数,例如:
1. `onLoad`: 页面加载时触发,可以在此函数中获取页面路径参数、从服务器获取数据等。
2. `onReady`: 页面初次渲染完成时触发。可以在此函数中获取节点信息、动态计算布局等。
3. `onUnload`: 页面卸载时触发,可以在此函数中取消监听器、清除定时器等。
4. `onShareAppMessage`: 用户点击右上角转发按钮或分享到朋友圈时触发。可以在此函数中定义需要分享的内容、动态生成图片等。
总之,生命周期函数是小程序中非常重要的一部分,开发者需要在不同情况下适时地调用这些函数,实现一些必要的 *** 作。
小程序的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()
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)