绕过微信不支持检测 HTML History PushState 变化的问题

栏目: Html · 发布时间: 6年前

内容简介:去年我在做一个 Web 项目的时候,发现「微信的内置浏览器不支持检测 HTML History PushState」,导致一些麻烦的事情。到了今年我发现微信依然没有解决这个问题,于是写篇 Blog 记录一下。简单地说,如果你在微信里面浏览一个网站,这个网站使用了 HTML History 的 PushState 来更改 URL 的话(现在已经有越来越多的采用 HTML5 技术的网站或 SPA 这样做了),微信会无视这个 URL 的变化,于是导致你在分享这个 URL 的时候,发现始终是这个网站的最初的 UR

去年我在做一个 Web 项目的时候,发现「微信的内置浏览器不支持检测 HTML History PushState」,导致一些麻烦的事情。到了今年我发现微信依然没有解决这个问题,于是写篇 Blog 记录一下。

什么是「不支持检测 HTML History PushState」?

简单地说,如果你在微信里面浏览一个网站,这个网站使用了 HTML History 的 PushState 来更改 URL 的话(现在已经有越来越多的采用 HTML5 技术的网站或 SPA 这样做了),微信会无视这个 URL 的变化,于是导致你在分享这个 URL 的时候,发现始终是这个网站的最初的 URL,而不是最新的 URL。

举个例子:

在微信里面访问 https://vue-hn.now.sh 这个网站,然后你通过右上角把该页分享给朋友,这时他会进入网址 https://vue-hn.now.sh ,这是对的。

然后,你点这个网站的任何一个条目的 Comments,进入这个条目的详细页,这时网址也会发生变化,比如变成了: https://vue-hn.now.sh/item/18037139 。这时,你再通过右上解把该页分享给朋友,你会发现虽然标题变了,但是网站仍然是老的。

这就是我前面说的「不支持检测 HTML History PushState 变化」。

解决方案 Workaround

现在都 2018 年了,我们总不能屈服于微信,把网站改成落后的技术,或者使用 Hash 模式的 History 导航。那么,怎么解决这个问题?我先直接上代码。

let ua = navigator.userAgent.toLowerCase()
if (ua.match(/MicroMessenger/i) == "micromessenger") {
    history.replaceState(history.state, null, window.location.pathname)
    let url = window.location.href
}

上面的代码很简单,可以放置在网页载入成功的位置,简单的说:

1、通过 User Agent 判断当前的环境是不是微信; 2、通过 history.replaceState 这个 API 强行载入一次同样的 URL,这个方法不会造成页面重新刷新,对用户来说是没有感知的,但是可以让微信知道网页发生变化了; 3、通过 window.location.href 取得当前的 URL,这时这个 URL 和微信检测到的 URL 是一致了,于是可以分享了。

总结

我这个方法不知道是不是最经济的,如果大家能找到更好的方法,欢迎告诉我。当然,这问题的本质还是微信的问题,如果有人能把这个问题转答给微信的核心开发人员并因此得到修复的话,这肯定是最好的。

但是因为 2017 年我就反馈过这个问题,现在依然没有得到修复,所以目前持悲观态度…

珍惜生命,远离「微信式 Web 开发」。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

连线

连线

加里·沃尔夫 / 黄锫坚 / 中国铁道出版社 / 2006-7 / 29.80元

简言之,是一个人和一本杂志的传奇……   放在大环境中,是一个时代的跌宕起伏……   一直大力地向所有人推荐这本书,只是因为,故事真的很精彩,是一个伟大而疯狂的时代所造就的一个不屈不挠的斗士——路易斯·罗塞托,还有这本举世皆知的杂志——《连线》。   通过本书,中国读者会知道,新经济热潮的主角不仅是比尔·盖茨、杨致远等技术和商业能人,还有一大批新文化的传教士和吹鼓手,比如路易斯·......一起来看看 《连线》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具