【微信小程序】小程序内部的优化,对我来说是个坑

背景:公司有好几款小程序,我负责的一款是论坛类的,其他小程序需要接入我的小程序。

我的小程序提供了论坛帖子详情页供其他小程序直接进入,传入帖子id即可
eg.

wx.navigateToMiniProgram({
  appId: 'xxxx', // 固定传参
  path: 'pages/public/bbs-post-detail?id=123', 
  envVersion: 'develop', // 'develop开发版 trial体验版 release正式版'
  extraData: {
  },
  success(res) {
  // 打开成功
  }
})

然后我的bbs-post-detail页面,在onShow里去接传入的参数。

至于为什么要在onShow里接呢,是因为onLoad只调用一次,如果用户先打开了论坛小程序,并且进入了帖子详情,那么从别的小程序跳转过来进帖子详情,就不会显示想要显示的帖子了。

所以一开始我的逻辑是,在onLoad中读取内部页面传参的options,并且获取帖子详情,在onShow里使用wx.getEnterOptionsSync()去获取别的小程序传过来的参数,并且判断进入场景是1037,就使用onShow获取到的id获取帖子详情。

本来一切都很正常,直到有一天发现有人触发了列表点击所有帖子进入详情都是同一篇帖子。

于是debug,于是发现:

小程序在onHide的时候,会将页面onLoad时的参数放入全局的options

猜测小程序这么干,是为了你下次再打开小程序时,依然还是跟你离开时的状态一样。

但是他并不会清除掉scene的值,并且,如果在帖子详情页调起分享的联系人界面,就会调用小程序或者页面的onHide(没有具体测是哪一个的onHide)。所以问题就来了,我详情页的onShow里面,能读到scene===1037并且能读取到有帖子id。

所以只要用户是从别的小程序来的,并且在详情页调用分享的联系人界面,那么这个用户每次从列表进详情页,都会走onShow的逻辑,取那个固定的帖子id。

解决方案:
在内部页面跳转中,加上一个from参数,用来标记是页面内部跳转进的详情页,并且在详情页的onShow里面判断如果有from并且是内部传的from,就不去wx.getEnterOptionsSync()了。搞定。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 要开发小程序首先要明白下面几个问题 我们如何创建小程序,如何对项目的目录结构分析? 一个小程序页面的生命周期是什么...
    YX_亚亚呀阅读 173评论 0 0
  • 1.搭建项目 创建新项目,你需要先注册一个小程序账号,当然也可以暂时先使用一个测试的 appid 小程序配置 2....
    aYaaWa阅读 585评论 0 0
  • 微信推出小程序后,有人看好,有人吃瓜观望.奔着对新事物保持好奇心的原则,尝尝鲜. 1.对象:移动端工程师(安卓,i...
    BeanDu阅读 2,050评论 0 0
  • 准备 微信小程序开发文档 官网 - https://developers.weixin.qq.com/minipr...
    squidbrother阅读 4,220评论 0 8
  • 1、你是怎么封装小程序数据请求的? 我们会在现在小程序根目录下,创建一个config.js作为一个独立的模块,用以...
    王云飞_小四_wyunfei阅读 2,672评论 0 4