微信H5适配 解决微信调整字体大小导致Html5页面混乱
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了微信H5适配 解决微信调整字体大小导致Html5页面混乱相关的知识,希望对你有一定的参考价值。
参考技术A 最近开发公众号遇到一个问题:ios、android 加载页面,如果用户调整了微信自带的字体大小,那么我们的页面就会跟随调整字体大小,导致页面错乱无法适配。所以希望能够禁止微信的字体放大功能。
找了一些方法总结如下:
原理:阻止ios和安卓调整字体大小时候的事件,ios通过添加css属性,安卓通过微信属性去阻止。
iOS系统禁止微信客户端修改字体大小:
Android 则通过js 调整:
禁止微信内置浏览器调整字体大小
微信webview内置了调整字体大小的功能,用户可以根据实际情况进行调节。
但是这也会导致字体大小改变以后,出现页面布局错乱的情况,目前iOS的解决方案是覆盖掉微信的样式:
body { /* IOS禁止微信调整字体大小 */
-webkit-text-size-adjust: 100% !important;
}
安卓的解决方案是通过 WeixinJSBridge 对象将网页的字体大小设置为默认大小,并且重写设置字体大小的方法,让用户不能在该网页下设置字体大小:
/*
* android禁止微信浏览器调整字体大小
*/
(function () {
if (typeof WeixinJSBridge == "object" && typeof WeixinJSBridge.invoke == "function") {
handleFontSize();
} else {
if (document.addEventListener) {
document.addEventListener("WeixinJSBridgeReady", handleFontSize, false);
} else if (document.attachEvent) {
document.attachEvent("WeixinJSBridgeReady", handleFontSize);
document.attachEvent("onWeixinJSBridgeReady", handleFontSize);
}
}
function handleFontSize() {
// 设置网页字体为默认大小
WeixinJSBridge.invoke(‘setFontSizeCallback‘, {
‘fontSize‘: 0
});
// 重写设置网页字体大小的事件
WeixinJSBridge.on(‘menu:setfont‘, function () {
WeixinJSBridge.invoke(‘setFontSizeCallback‘, {
‘fontSize‘: 0
});
});
}
})();
以上是关于微信H5适配 解决微信调整字体大小导致Html5页面混乱的主要内容,如果未能解决你的问题,请参考以下文章