【移动端】【font boosting】移动端开发,字体大小被调整,跟真实大小不一样

【移动端】【font boosting】移动端开发,字体大小被调整,跟真实大小不一样

问题缘由:做文章详情页的时候,文字多了一点字体就放大了,真的是奇了怪了。

问题重现

一段文字的时候
1225466-20180423104645622-1137863848.png

两段文字的时候
1225466-20180423104701490-467980670.png

很明显,字体放大了很多。

疑点

meta标签缩放的问题

最近正好遇到处理retain屏1px的问题,然后采用的是自动修改meta标签。


/**
 * Created by jarjune on 2017/7/26.
 */
(function (doc, win) {
  var scale = 1.0;
  var ratio = 1;
  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'
  }

  if (!doc.addEventListener) return
  recalc()
  win.addEventListener(resizeEvt, recalc, false)
  // doc.addEventListener('DOMContentLoaded', recalc, false)
})(document, window);

window.devicePixelRatio == 1时,没有发现字体自动放大的问题。

window.devicePixelRatio == 2或者window.devicePixelRatio == 3时,问题就出现了。

科学解释【Font Boosting】

这个特性被称做「Text Autosizer」,又称「Font Boosting」、「Font Inflation」,是 Webkit 给移动端浏览器提供的一个特性:当我们在手机上浏览网页时,很可能因为原始页面宽度较大,在手机屏幕上缩小后就看不清其中的文字了。而 Font Boosting 特性在这时会自动将其中的文字字体变大,保证在即不需要左右滑动屏幕,也不需要双击放大屏幕内容的前提下,也可以让人们方便的阅读页面中的文本。

解决方案

  1. <meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width, user-scalable=no"> 缩放比设为1,至于1px之类的问题可以采取其他方案解决。
  2. 给元素指定高度(想想是不太现实的),不过设置max-height:99999px也有效。
  3. 设置text-size-adjust:none,不过大部分浏览器都不兼容。

【2018-10-21补】

问题代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>测试</title>
    <script type="text/javascript" src="js/rem.js"></script>
    <link rel="stylesheet" type="text/css" href="css/base.css">
</head>
<body>
<p style="font-size: .28rem;">测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测</p>
<p style="font-size: .28rem;">测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测</p>
</body>
</html>

经过又一次测试发现,同样的代码,在安卓上文字会自动变大,在ios的3x屏上文字会自动变小,
上文说的设置max-height:99999px只是在安卓上有用,在3x屏上,需要设置width为一个固定的值才有效,比如7.5rem,注意!设置100%也无效!

修改后的代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>测试</title>
    <script type="text/javascript" src="js/rem.js"></script>
    <link rel="stylesheet" type="text/css" href="css/base.css">
</head>
<body>
<p style="font-size: .28rem; max-height: 99999px; width: 7.5rem;">测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测</p>
<p style="font-size: .28rem; max-height: 99999px; width: 7.5rem;">测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测</p>
</body>
</html>

最终方案

  1. <meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width, user-scalable=no"> 缩放比设为1,至于1px之类的问题可以采取其他方案解决。
  2. height设置max-height:99999pxwidth设置固定大小。
  3. 设置text-size-adjust:none,不过大部分浏览器都不兼容。
posted @ 2018-04-23 10:46 jarjune 阅读( ...) 评论( ...) 编辑 收藏
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值