uni-app的h5页面中onHide/onUnload方法不触发的问题解决方法
更新时间:2023年12月27日 08:23:35 作者:洛千陨
uni-app的页面的生命周期包括onInit、onLoad、onShow、onReady、onHide和onUnload等几个阶段,这篇文章主要给大家介绍了关于uni-app的h5页面中onHide/onUnload方法不触发的问题解决方法,需要的朋友可以参考下
背景
- 目的:对h5页面进行埋点过程中,需要对页面浏览时长进行统计,通过生命周期的监听上传埋点日志
- 预设方案:通过个页面的onShow/onHide/onUnload生命周期对页面的展示/隐藏/销毁进行监听
- 问题:仅在首页正常触发生命周期,通过跳转进入的其他页面的onShow正常触发,onHide与onUnload不触发
解决过程
- 推测原因:通过路由跳转的页面属于二级页面,而onHide与onUnload生命周期仅在一级页面中存在
解决方法
- 二级页面:
- onShow:正常使用该生命周期监听页面显示,包括后台进前台与路由跳转进入
- destroyed:用组件生命周期代替onHide与onUnload,监听路由跳转离开
- app.vue:
- onHide:应用生命周期对整个应用的前台进入后台进行监听,通过url区分不同页面的埋点日志上传
示例代码
// 一级页面-首页
onShow() {
this.$$DI.track('enter_page', {
page_name: '首页'
})
},
onHide() {
this.$$DI.track('leave_page', {
page_name: '首页'
})
},
onUnLoad() {
this.$$DI.track('leave_page', {
page_name: '首页'
})
},
// 二级页面
onShow() {
this.$$DI.track('enter_page', {
page_name: 'a页面'
})
},
destroyed() {
this.$$DI.track('leave_page', {
page_name: 'a页面'
})
}
// app.vue
onHide() {
let page_name
// 根据需要监听的页面路由进行判断添加
if(window.location.href.includes('basic')) page_name = 'a页面'
if(page_name) {
this.$$DI.track('leave_page', {
page_name
})
}
},总结
到此这篇关于uni-app的h5页面中onHide/onUnload方法不触发的问题解决方法的文章就介绍到这了,更多相关uni-app onHide/onUnload方法不触发内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
js对象实例详解(JavaScript对象深度剖析,深度理解js对象)
下面小编就为大家带来一篇js对象实例详解(JavaScript对象深度剖析,深度理解js对象)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-09-09
JavaScript 轮播图和自定义滚动条配合鼠标滚轮分享代码贴
本文给大家分享一段js轮播图和自定义滚动条的代码片段,布局和样式小编没给大家多介绍,大家可以根据个人需求优化,具体实现代码,大家可以参考下面代码片段2016-10-10


最新评论