需求
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,所以我们可以直接设置。
其他解决方案
- 添加css
border: 1px solid transparent; box-sizing: border-box - 不适用line-height,使用其他方式垂直居中