uni-app的h5页面的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
        })
    }
},

文章来源地址https://www.toymoban.com/news/detail-624225.html

到了这里,关于uni-app的h5页面的onHide/onUnload方法不触发的问题解决的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包