em和rem笔记

简单介绍

单位

在编写网页过程中,需要对元素(标签)进行宽高、颜色、字体等的设置,这些需要使用单位。
在CSS中,设置字体和宽高使用的单位可以一致,例如:px / em / rem / 百分比

rem来源

rem 是CSS3中的单位

和px的关系

px 是使用最多的单位;
emrem 可以和 px 单位进行换算,就比如 里和公里 之间可以换算一样;

建议

在做移动端项目的时候,建议使用 rem 作为使用单位
这样可以方便 、 快捷 、 容易的实现响应式的效果

em详细说明

em 就是参照父级元素大小
如果父元素 font-size: 20px; ,给子元素设置字体 font-size: 1em; ,子元素其实就是 20px 的大小

eg:

  • 设定 1em = 20px
  • 2em = 40px
  • 0.6em = 12px

em 合适的使用场景是:text-indent(首行缩进) / line-height(行高)

rem详细说明

rem 参考的是html标签的字体大小

remem 不同点就是 em 参考各自的父元素,如果父元素没有设置字体大小,则继续向上查找(父父元素) , 直至最后
rem 直接参照 html 标签字体大小,并且是所有使用 rem 单位的都是 html 标签
所以只需要更改 html 标签字体大小,就可以影响全部使用 rem 单位的标签

代码示例

html{
    font-size: 100px;
}
.title{
    width: 5rem;/*500px*/
    height: 5rem;/*500px*/
    font-size: .3rem;/*30px*/
}

在做响应式网站时,可以根据媒体查询去调节 html 标签的字体大小,实现共同调节其他标签大小的效果
使用媒体查询调节 html 字体大小,效果不够精细(大小是分段改变的),可以使用 JavaScript 动态计算html的 font-size

使用注意点

在rem使用过程中,要时刻注意 字体最小12px 的问题
设置 html的font-size 属性的时候,最好 不要小于12px
如果设置了 10px使用1rem 的时候,其实 是12px,因为最小12px

你可能感兴趣的:(em和rem笔记)