安卓端使用line-height垂直居中偏移1px问题解决

2,494 阅读1分钟

需求

1. 显示一个重新加载按钮
2. 文本垂直居中

基本样式

    .refresh-btn {
      width 240px
      height 80px
      line-height 80px
    }

问题:

网页端显示正常,ios手机正常,安卓端出现按钮内文本偏上

原因:

是Android在排版计算的时候参考了primyfont字体的相关属性(即HHead Ascent、HHead Descent等),而primyfont的查找是看font-family里哪个字体在fonts.xml里第一个匹配上,而原生Android下中文字体是没有family name的,导致匹配上的始终不是中文字体,所以解决这个问题就要在font-family里显式申明中文,或者通过什么方法保证所有字符都fallback到中文字体。

部分机型解决方案:

1.针对Android 7.0+设备: html 上设置 lang 属性: html lang="zh-cmn-Hans" ,同时font-family不指定英文,如 font-family: sans-serif 。这个方法是利用了浏览器的字体fallback机制,让英文也使用中文字体来展示,blink早期的内核在fallback机制上存在问题,Android 7.0+才能ok,早期的内核下会导致英文fallback到Noto Sans Myanmar,这个字体非常丑。

2.针对MIUI 8.0+设备:设置 font-family: miui 。这个方案就是显式申明中文的方案,MIUI在8.0+上内置了小米兰亭,同时在fonts.xml里给这个字体指定了family name:miui,所以我们可以直接设置。

其他解决方案

  1. 添加css
        border: 1px solid transparent;
        box-sizing: border-box
    
  2. 不适用line-height,使用其他方式垂直居中