绕过微信不支持检测 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 开发」。


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

查看所有标签

猜你喜欢:

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

Python基础教程

Python基础教程

[挪] Magnus Lie Hetland / 袁国忠 / 人民邮电出版 / 2018-2-1 / CNY 99.00

本书包括Python程序设计的方方面面:首先从Python的安装开始,随后介绍了Python的基础知识和基本概念,包括列表、元组、字符串、字典以及各种语句;然后循序渐进地介绍了一些相对高级的主题,包括抽象、异常、魔法方法、属性、迭代器;此后探讨了如何将Python与数据库、网络、C语言等工具结合使用,从而发挥出Python的强大功能,同时介绍了Python程序测试、打包、发布等知识;最后,作者结合......一起来看看 《Python基础教程》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具