禁止微信内置浏览器调整字体大小

微信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

    });

  });

  }
})();

 
posted @   SKILL·NULL  阅读(9139)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
历史上的今天:
2015-10-08 JS打造的跟随鼠标移动的酷炫拓扑图案
点击右上角即可分享
微信分享提示