我的翻译,转载请注明出处
英文原文:CSS Font Sizingcss
上一篇文章如何作好移动端的响应式设计:Viewport控制讨论到了CSS像素,因而我决定研究一下如何用不一样的方式来在CSS中设定字体大小。html
在CSS中能够用不少不一样的方式来设定字体的尺寸。通常来讲,这些单位被分红两大类:绝对单位(absolute)和相对单位(relative)。segmentfault
下面是对这些单位的一个简单整理:浏览器
单位 | 类型 | 描述 |
---|---|---|
px | Absolute | 1个Viewport像素 |
pt | Absolute | 1pt = 1/72英寸 |
pc | Absolute | 1pc = 12pt |
% | Relative | 相对于父元素的字体尺寸 |
em | Relative | 相对于父元素的字体尺寸 |
rem | Relative | (即root em) 相对于html标签的字体尺寸 |
keyword | Relative | xx-small, x-small, small, medium, large, x-large, xx-large |
vw | Relative | 至关于Viewport宽度的1/100 |
vh | Relative | 至关于Viewport高度的1/100 |
vmin | Relative | 至关于Viewport高宽中长度相对较小的1/100 |
vmax | Relative | 至关于Viewport高宽中长度相对较大的1/100 |
这里主要关注这几个单位:px
、pt
、%
、em
、rem
和vw
。字体
从概念上很难理解这些单位之间的差异,因此下面用一些实例来讲明。优化
当你不设定字体尺寸时,HTML会提供一个默认的尺寸设定。大多数浏览器中<html>
和<body>
标签中的默认字体尺寸是100%
,没有概念?看这个等式:spa
100% = 1em = 1rem = 16px = 12pt翻译
仍是不懂?那就换个说法,好比说你给一个<p>
设置字体尺寸为100%
,给另外一个<p>
设置为16px
,在屏幕上看到的这两个<p>
中的字体大小是同样的,下图列出了用几个不一样单位设置的字体尺寸,能够看出是同样大的:设计
改变<html>
的字体尺寸能够很明显的看出绝对单位和相对单位的差异。若是把<html>
设置为html { font-size: 200% }
,就会影响全部使用相对单位的<p>
。效果以下图:
这就是相对单位最主要的优点了,借助相对单位的这种特性就能够设计出真正的响应式页面,而所要作的只是修改<html>
的字体尺寸code
rem
与em
(或者%
)em
(或者%
)须要经过父元素的字体尺寸来计算尺寸:
html { font-size: 100% /* =16px */ } body { font-size: 2em; /* =32px */ } p { font-size: 1em; /* =32px */ /* font-size: 0.5em; =16px */ }
由于<p>
是<body>
的子元素,而<body>
是<html>
的子元素,因此<p>
中的em
和%
将是以前的两倍。
当你为一个元素添加em
单位时,应当考虑到全部父元素的字体尺寸。如你所见,这样很容易令人混乱。
使用rem
能够很好的解决这个问题。rem
只须要计算<html>
的字体尺寸而不须要考虑父元素。以下代码所示:
html { font-size: 100% /* =16px */ } body { font-size: 2rem; /* =32px */ } p { font-size: 1rem; /* =16px */ }
使用rem
可让你拥有和em
/%
一样的缩放能力,但没必要去考虑那些复杂的嵌套关系。
vw
是CSS3中新提出的一个单位,经过Viewport宽度来计算字体尺寸。这样就能够设计出更加灵活的响应式字体。
虽然这个单位看上去很是适合用于响应式设计,但就我我的而言不是很热衷于它。在使用vw
的过程当中我并不能很好的控制字体的大小,不是太大就是过小。
当我在写这篇文章时,我仅使用px
来做为单位。由于如今大多数浏览器都容许用户放大页面,这样作就不会有可访问性的问题。
然而,我发现了这个具备必定限制力的方式。虽然个人字体尺寸在中小型屏幕上看起来还行,但在大屏幕上会被优化的更好。尽管用户能够自行设定放大的属性,可是咱们但愿能够尽可能减小用户的工做。
个人解决方案是使用rem
,并使用px
做为备用单位。
html { font-size: 62.5%; /* sets the base font to 10px for easier math */ } body { font-size: 16px; font-size: 1.6rem; /* sets the default sizing to make sure nothing is actually 10px */ } h1 { font-size: 32px; font-size: 3.2rem; }
像下面这样写就能够容许我按比例来放大个人字体尺寸:
@media screen and (min-width: 1280px) { html { font-size: 100%; } }
这个方案之因此使用px
做为备用单位,是由于rem
不支持IE8及其如下版本。这个方案有一个问题,就是像上面这样改变基础字体尺寸时,并不能对备用字体尺寸起到做用。不过,我不以为这个问题多么大,由于这个匹配大型设备尺寸的能力只不过是为了锦上添花而已,并非一个核心功能。
若是你在这个问题上有一些更好的点子,能够评论或私信给我。