- 小程序生命周期
初始化(App Launch)
• 触发时机:小程序首次启动时。
• 主要事件:onLaunch。
• 功能与适用场景:
• 全局数据初始化:设置应用的全局状态和变量。
• 登录状态检查:判断用户是否已登录,决定是否跳转到登录页面。
• 加载配置:加载应用的基础配置,如网络请求的基础设置。
• 性能监控:初始化性能监控工具,记录启动时间等。
• 示例代码:
App({
onLaunch: function(options) {
console.log("小程序启动");
this.checkUserLogin();
this.loadAppConfig();
},
checkUserLogin: function() {
// 检查用户登录状态
},
loadAppConfig: function() {
// 加载应用配置
}
});
前台显示(App Show)
• 触发时机:小程序从后台切换到前台,或初次启动时。
• 主要事件:onShow。
• 功能与适用场景:
• 数据刷新:从服务器获取最新数据,更新页面显示。
• 恢复用户操作:继续用户的未完成操作,如暂停的音频或视频。
• 状态检查:检查用户设备状态或地理位置。
• 示例代码:
App({
onShow: function(options) {
console.log("小程序进入前台");
this.refreshData();
this.resumeUserAction();
},
refreshData: function() {
// 刷新数据
},
resumeUserAction: function() {
// 恢复用户操作
}
});
后台运行(App Hide)
• 触发时机:小程序从前台切换到后台,或用户打开其他小程序。
• 主要事件:onHide。
• 功能与适用场景:
• 数据保存:保存当前页面的状态和数据。
• 资源释放:暂停或停止不必要的资源消耗,如视频播放或计时器。
• 后台任务:继续执行一些后台任务,如数据同步。
• 示例代码:
App({
onHide: function() {
console.log("小程序进入后台");
this.saveCurrentData();
this.releaseResources();
},
saveCurrentData: function() {
// 保存当前数据
},
releaseResources: function() {
// 释放资源
}
});
错误处理(App Error)
• 触发时机:小程序发生脚本错误或 API 调用失败时。
• 主要事件:onError。
• 功能与适用场景:
• 错误日志记录:记录详细的错误信息,便于后续分析和调试。
• 错误上报:将错误信息上传到服务器进行监控。
• 用户提示:提示用户发生错误,提供解决建议或引导。
• 示例代码:
App({
onError: function(msg) {
console.error("小程序出错:", msg);
this.logError(msg);
this.reportError(msg);
},
logError: function(msg) {
// 记录错误日志
},
reportError: function(msg) {
// 上报错误信息
}
});
- 页面生命周期
每个页面都有自己的生命周期函数,用于管理页面的加载、渲染、显示、隐藏等状态。
页面加载(onLoad)
• 触发时机:页面加载时触发,通常在用户进入页面时。
• 适用场景:
• 数据初始化:加载页面所需的初始数据。
• 动态内容设置:根据页面参数,动态设置内容或状态。
• API调用:获取页面所需的详细信息,如商品详情。
• 示例代码:
Page({
onLoad: function(options) {
console.log("页面加载", options);
this.loadData(options);
},
loadData: function(options) {
// 加载数据
}
});
页面显示(onShow)
• 触发时机:页面显示时触发,每次页面从后台切换到前台都会执行。
• 适用场景:
• 数据刷新:检查和更新可能在后台变化的数据。
• UI更新:刷新界面,确保显示最新内容。
• 用户交互准备:重置与用户交互相关的状态或组件。
• 示例代码:
Page({
onShow: function() {
console.log("页面显示");
this.refreshPageData();
},
refreshPageData: function() {
// 刷新数据
}
});
页面初次渲染完成(onReady)
• 触发时机:页面初次渲染完成时触发,仅在页面首次渲染完成时调用一次。
• 适用场景:
• 组件初始化:初始化需要页面完全加载后处理的组件,如图表、地图等。
• 动画效果:启动需要页面完全加载后的动画。
• 示例代码:
Page({
onReady: function() {
console.log("页面初次渲染完成");
this.initChart();
},
initChart: function() {
// 初始化图表
}
});
页面隐藏(onHide)
• 触发时机:页面被隐藏时触发,比如进入下一个页面或切换到后台。
• 适用场景:
• 状态保存:保存当前页面的状态,以便返回时能够继续。
• 资源释放:暂停或停止不必要的资源消耗。
• 示例代码:
Page({
onHide: function() {
console.log("页面隐藏");
this.savePageState();
this.releasePageResources();
},
savePageState: function() {
// 保存状态
},
releasePageResources: function() {
// 释放资源
}
});
页面卸载(onUnload)
• 触发时机:页面卸载时触发,比如从当前页面导航到另一个页面。
• 适用场景:
• 清理操作:在页面卸载时进行清理,如删除临时数据、停止监听等。
• 断开连接:关闭实时数据连接(如 WebSocket)。
• 示例代码:
Page({
onUnload: function() {
console.log("页面卸载");
this.cleanup();
this.disconnect();
},
cleanup: function() {
// 清理操作
},
disconnect: function() {
// 断开连接
}
});
-
生命周期的实际应用场景
- 用户登录管理
• 初始化检查:在 onLaunch 中检查用户是否已登录。
• 登录状态刷新:在 onShow 中刷新用户的登录状态。
• 后台状态保存:在 onHide 中保存登录状态。 - 数据同步和更新
• 页面加载数据:在 onLoad 中通过 API 调用加载数据。
• 前台数据刷新:在 onShow 中更新关键数据。
• 后台任务继续:在 onHide 中保持数据同步任务。 - 性能优化
• 资源管理:在 onReady 中初始化需要完全加载的组件。
• 资源释放:在 onHide 和 onUnload 中释放不必要的资源。
• 错误处理和监控:在 onError 中记录和上报错误。 - 用户体验提升
• 个性化设置:在 onLoad 和 onShow 中动态更新内容。
• 动画效果:在 onReady 中启动页面动画。
• 操作恢复:在 onShow 中恢复用户未完成的操作。
- 用户登录管理
总结
了解并合理利用小程序的生命周期,对于开发稳定、高效的应用至关重要。每个阶段都有特定的功能和适用场景,开发者应根据具体需求,灵活处理生命周期事件,以提升应用的用户体验和性能。