最近搞移动端,真是被rem、em与px的换算要了老命了,看了很多文档,彷佛弄明白了,这不今天用又蒙圈了。html
好多文档上总是说用rem就给html设置font-size,用em就给body设置font-sizebootstrap
看了下bootstrap样式表,html {font-size:62.5%;} body {font-size:14px;},其余样式略哈,就讲这两个主要的。学习
惋惜大姐长了这么大眼睛,从昨天到今天一直把em当作了rem,致使越算越郁闷……好不说了,解释以下:测试
其实能够学习bootstrap的这种设置,由于在用到em和rem的时候互不影响,由于rem就是去参照你html的font-size,管你body设不设置,都与我不要紧。spa
1、那么若是你肯定要使用rem单位,就按如下三个步骤来计算:htm
一、肯定基数:通常10px,本身记住就行,不用写进代码里rem
二、html {font-size:百分数;} 百分数=基数/16 文档
基数10 百分数62.5%容器
基数14 百分数87.5%百度
三、px换算rem 公式=想要的px值/基数
也就是说,当你设置 html {font-size:62.5%;},你想给容器里的文字设置字号14px,换算成rem就是14px/10——1.4rem 这样子
(若是本身想要测试的话,拿火狐Firebug测试,由于Chrome下字号低于12px失效哈,若是想设置小于12px的字号,Chrome也有解决方案,本身百度就好)
2、若是使用em单位的时候,计算机就会本身去找你body的设置,才不会管你html是如何设置的呢
好比咱们伟大的bootstrap给 body {font-size:14px;} 这样设置后,若是我想要一个14px的外边距,我就用14px/14px——1em 这样啦。
以上是我本身总结的,若有错误,欢迎你们来指正哦~~