系统字体大小导致rem布局变大

Posted jarjune

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了系统字体大小导致rem布局变大相关的知识,希望对你有一定的参考价值。

缘由:内部测试都ok,交给客户看的时候,整天变大,本来7.5rem = 750px,实际上大了很多。

各种情况排除后,发现是客户手机字体大小调整到了特大

解决办法

getComputedStyle方法能够获取到计算后的样式、大小。

最后优化完的代码如下。


    (function (doc, win) {

      var isandroid = win.navigator.appVersion.match(/android/gi);
      var isIPhone = win.navigator.appVersion.match(/iphone/gi);

      var scale = 1.0;
      var ratio = 1;
      if(isIPhone) {
        if (window.devicePixelRatio == 2) {
          scale *= 0.5;
          ratio *= 2;
        }
        if (window.devicePixelRatio == 3) {
          scale *= (1/3);
          ratio *= 3;
        }
      }
      var text = '<meta name="viewport" content="initial-scale=' + scale + ', maximum-scale=' + scale + ',' + ' minimum-scale=' + scale + ', width=device-width,' + ' user-scalable=no" />';
      document.write(text);

      var docEl = doc.documentElement
      var resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize'
      var recalc = function () {
        var clientWidth = docEl.clientWidth
        if (!clientWidth) return
        docEl.style.fontSize = 100 * (clientWidth / 750)  + 'px'

        // 解决部分rem特别大的问题
        var docElFontSize = docEl.style.fontSize.replace(/px/gi, '')
        var computedFontSize = win.getComputedStyle(docEl)['font-size'].replace(/px/gi, '')
        docElFontSize != computedFontSize && (docEl.style.fontSize = docElFontSize * docElFontSize / computedFontSize + 'px')
      }
      if (!doc.addEventListener) return
      recalc()
      win.addEventListener(resizeEvt, recalc, false)
    })(document, window);

以上是关于系统字体大小导致rem布局变大的主要内容,如果未能解决你的问题,请参考以下文章

移动端rem布局,用户调整手机字体大小或浏览器字体大小后导致页面布局出错问题

pc端jquery项目开发总结

解决因为手机设置字体大小导致h5页面在webview中变形的BUG

rem适配,解决用户设置系统字体大小导致样式错乱问题

移动端布局rem em

rem布局,在用户调整手机字体大小/用户调整浏览器字体大小后,布局错乱问题