微信小程序分享页面,decodeURIComponent()解码的参数的问题

相信不少同学在开发微信小程序的开发中,有不少同学涉及到分享的功能,分享 api 我们可以通过查阅微信官方文档知道 onShareAppMessage 方法。

其中这个方法接受一个 path 参数,也就是我们要分享的页面,当 path 带参数时,我们知道 ?后面的参数会被浏览器忽略掉,所以我们一般会对其进行 encodeURIComponent,使用时进行相应的 decodeURIComponent 便可。

但是最近却出现一个问题,小程序二次分享页面竟然打不开了,查其原因发现是二次分享时 decodeURIComponent 不起作用。

可是明明拿到参数后 decodeURIComponent 了呀,为何 decodeURIComponent 后的参数还是未解码的:

decodeURIComponent 后的参数还是未解码

诡异的是,第一次分享的时候没有问题,这问题仅出现在二次分享时。

于是,开始一顿排查,终于找到原因 。

原来浏览器对链接带的参数又编码了一次,解码的时候需要解两次码才能得到原先的数据 。

于是我三下五除二又加了一层解码,立马进行验证:

 const { url = "" } = this.$router.params;
 const webUrl = `${HOST}${decodeURIComponent(decodeURIComponent(url))}`;

惊喜,二次分享成功打开页面,打印出来的参数也是正常解码后的参数。

但是我立马又联想到,三次四次五次等以上分享呢,果断测试了一下,上面的代码果然不顶用,这就要求我们进行一个判断了。

我这边用到了递归来解决,具体实现如下:

getUrl (url) {
    if (url.indexOf('%') < 0) {
      return url
    } else {
      const newUrl = decodeURIComponent(url)
      return this.getUrl(newUrl)
    }
}

const { url = "" } = this.$router.params;
const webUrl = `${HOST}${getUrl(url))}`;

当然,小伙伴们还可以通过循环去解决,道理是一样的。

原文:链接

「点点赞赏,手留余香」

2

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » 微信小程序分享页面,decodeURIComponent()解码的参数的问题

发表回复