安卓移动端line-height垂直居中出现偏移的解决方法

满堂花醉三千客,一剑霜寒十四州。这篇文章主要讲述安卓移动端line-height垂直居中出现偏移的解决方法相关的知识,希望能为你提供帮助。
目前移动端在项目使用的rem,安卓手机上line-height属性,让它的值等于height,结果发现是不居中的。
出现此问题的原因是android在排版计算的时候参考了primyfont字体的相关属性(即HHead Ascent、HHead Descent等),而primyfont的查找是看`font-family`里哪个字体在fonts.xml里第一个匹配上,而原生Android下中文字体是没有family name的,导致匹配上的始终不是中文字体,所以解决这个问题就要在`font-family`里显式申明中文,或者通过什么方法保证所有字符都fallback到中文字体。
解决方法:
【安卓移动端line-height垂直居中出现偏移的解决方法】1、添加border相关属性:

  • border: 1px solid transparent;
2、针对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,这个字体非常丑。
3、针对MIUI 8.0+设备:
  • 设置 font-family: miui 。这个方案就是显式申明中文的方案,MIUI在8.0+上内置了小米兰亭,同时在fonts.xml里给这个字体指定了family name:miui,所以我们可以直接设置。

    推荐阅读