关于前端:禁止微信内置浏览器调整字体大小

微信webview内置了调整字体大小的性能,用户能够依据理论状况进行调节。

然而这也会导致字体大小扭转当前,呈现页面布局错乱的状况,目前iOS的解决方案是笼罩掉微信的款式:

body { /* IOS禁止微信调整字体大小 */
    -webkit-text-size-adjust: 100% !important;
}

安卓的解决方案是通过 WeixinJSBridge 对象将网页的字体大小设置为默认大小,并且重写设置字体大小的办法,让用户不能在该网页下设置字体大小:

/*

  • android禁止微信浏览器调整字体大小
  •  这种办法会导致网页提早大概1S

*/

(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

    });

  });

  }
})();

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理