px
像素(Pixel)。相对长度单位。像素px是相对于显示器屏幕分辨率而言的。em
是相对长度单位。相对于当前对象内文本的字体尺寸。如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸任意浏览器的默认字体高都是16px。所有未经调整的浏览器都符合: 1em=16px
。那么12px=0.75em
,10px=0.625em
。为了简化font-size的换算,需要在css中的body选择器中声明Font-size=62.5%
,这就使em值变为 16px*62.5%=10px
, 这样12px=1.2em
, 10px=1em
, 也就是说只需要将你的原来的px数值除以10,然后换上em作为单位就行了。
em
指的是一个字体的大小,它会继承父级元素的字体大小,因此并不是一个固定的值。任何浏览器的默认字体大小都是16px。因此,12px = 0.75em。实际应用中为了方便换算,通常会如下设置样式:
CSS代码如下:
html { font-size: 62.5%; }
这样,1em = 10px。我们常用的1.2em理论上就是12px。但是,这个换算在IE浏览器下不成立,1.2em会比12px稍大一些,解决办法是把html标签样式中的62.5%改成63%,即:
CSS代码如下:
html { font-size: 63%; }
在 中文的文章中,一般会在段首空两格。如果用px作为单位,对12px字体来说需要空出24px,对14px字体来说需要空出28px……这样换算非常不通 用。如果用上em单位,这个问题就很好解决了,1个字的大小就是1em,那两个字的大小就是2em。因此,只需这样定义就行了:
CSS代码如下:
p { text-indent: 2em; }
rem
是CSS3新增的一个相对单位(root em,根em),这个单位引起了广泛关注。
这个单位与em有什么区别呢?区别在于使用rem为元素设定字体大小时,仍然是相对大小,但相对的只是HTML根元素。
这个单位可谓集相对大小和绝对大小的优点于一身,通过它既可以做到只修改根元素就成比例地调整所有字体大小,又可以避免字体大小逐层复合的连锁反应。
目前,除了IE8及更早版本外,所有浏览器均已支持rem。
对于不支持它的浏览器,应对方法也很简单,就是多写一个绝对单位的声明。这些浏览器会忽略用rem设定的字体大小。
举例:
p {font-size:14px; font-size:.875rem;}
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8