目前iOS的解决方案是覆盖掉微信的样式:
/* IOS禁止微信调整字体大小 */
body { -webkit-text-size-adjust: 100% !important; }
安卓的解决方案是经过 WeixinJSBridge 对象将网页的字体大小设置为默认大小,而且重写设置字体大小的方法,让用户不能在该网页下设置字体大小:
/*
* android禁止微信浏览器调整字体大小android
* 这种方法会致使网页延迟大约1Sweb
*/segmentfault
//android禁止微信浏览器调整字体大小 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 }); }); }
这样解决会出现的问题:浏览器
一、若是用户在标准状况下,打开页面。再调整字体大小,那么页面依旧正常。微信
二、若是用户先调整了字体大小,再打开页面,页面会变大,一秒以后恢复正常。布局
注:采用loading,可解决2的问题字体