搭建前端页面时,较为常用的长度单位就是px、em、rem。
px(pixel):相对长度单位,像素px是相对于显示器屏幕分辨率而言的。
特点
IE无法调整哪些使用px作为单位的字体大小;国外大部分网站嫩够调整的原因在于其使用了em或rem作为字体单位;Firefox能够调整px和em、rem,但是有大部分的国产浏览器使用IE内核。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的值并不是固定的;em会继承父级的字体大小;在写css时,需要注意三点:
body选择器中声明font-size=62.5%;将原来的px数值除以10,换上em作为单位;重新计算那些被放大的字体的em数值,避免字体大小的重复声明。rem:rem是CSS3中新增的一个相对单位(root em)。其相对于根元素,只需要在根元素确定一个参考值。
特点
rem相对单位,相对于根元素;相对大小和绝对大小的优点于一身;修改根元素就成比例的调整所有字体大小;避免字体大小逐层复合的连锁反应 对于支持rem的浏览器,需要多写一个绝对单位声明,浏览器就会忽略用rem设定的字体大小。 P{font-size:14px;font-size:.5rem;}**ps:**选择使用什么字体单位主要由你的项目来决定,如果你的用户群都使用最新版的浏览器,那就推荐使用rem,如果考虑兼容,那就使用px,或者两者都使用。 px、em、rem单位转换地址:http://pxtoem.com/
1. 使用px设置字体大小时存在的问题: 当用户浏览web页面时,如果改变了浏览器的缩放,web页面的布局就会被打破。这样对于关心自己网站可用性的用户来说,就是一个大问题了,这时就可以使用“em”来定义web页面的字体。
2.
媒体查询中使用 rem 单位。不要在多列布局中使用 em 或 rem ,改用%。不要使用 em 或 rem,如果缩放会不可避免地导致要打破布局元素。3.浏览器的兼容性 除了IE6-IE8,其它的浏览器都支持em和rem属性,px是所有浏览器都支持。 因此为了浏览器的兼容性,可“px”和“rem”一起使用,用"px"来实现IE6-8下的效果,然后使用“rem”来实现代浏览器的效果。