你不知道的css各类布局(五)之em布局、rem布局

em布局/rem布局

em和rem的区别

在了解弹性布局前我们需要先知道em和rem

rem:font size of the root element,rem是相对于根元素<html>来设置字体大小的,这就意味着,我们只需要根据自己的需求在根元素确定一个参考值。

em:以使用em为单位的元素本身的font-size大小为参考点,标准不统一,容易造成混乱

em/rem与px的换算

浏览器的默认字体高度一般为16px,即1em:16px,但是 1:16 的比例不方便计算,为了使单位em/rem更直观,CSS编写者常常将页面跟节点字体设为62.5%,比如选择用rem控制字体时,先需要设置根节点html的字体大小,因为浏览器

默认字体大小16px*62.5%=10px。这样1rem便是10px,方便了计算。

那么为什么一般多是 html{font-size:62.5%;} 而不是 html{font-size:10px;}呢?

因为有些浏览器默认的不是16px,或者用户修改了浏览器默认的字体大小(因浏览器分辨率大小,视力,习惯等因素)。如果我们将其设置为10px,一定会影响在这些浏览器上的效果,所以最好用绝大多数用户默认的16作为基数 * 62.5%

得到我们需要的10px。

html {font-size: 62.5%;/*10 ÷ 16 × 100% = 62.5%*/}
body {font-size: 1.4rem;/*1.4 × 10px = 14px */}
h1 { font-size: 2.4rem;/*2.4 × 10px = 24px*/}

实际项目设置成 font-size: 62.5%可能会出现问题,因为chrome不支持小于12px的字体,计算小于12px的时候,会默认取12px去计算,导致chrome的em/rem计算不准确。

针对这个现象,可以尝试设置html字体为100px,body 修正为16px,这样 0.1rem 就是 10px,而body的字体仍然是默认大小,不影响未设置大小的元素的默认字体的大小。

概念

弹性布局是指通过调整其内元素的宽高(弹性容器扩展其内元素来填充可用空间,或将其收缩来避免溢出),从而在任何显示设备上实现对可用显示空间最佳填充的能力

布局特点

这类布局的特点是,包裹文字的各元素的尺寸采用em/rem做单位,使用 em 或 rem 单位进行相对布局,相对%百分比更加灵活,同时可以支持浏览器的字体大小调整和缩放等的正常显示,因为em是相对父级元素的原因没有得到推广,

使用rem单位的弹性布局在移动端也很受欢迎

其实在移动端使用所谓的弹性布局,是比较勉强的。移动端弹性布局流行起来的原因归根结底是rem单位对于(根据屏幕尺寸)调整页面的各元素的尺寸、文字大小时比较好用。其实,使用vw、vh等后起之秀的单位,可以实现完美的流式

布局(高度和文字大小都可以变得“流式”),弹性布局就不再必要了。

优点

  • 如果执行正确,这种布局方式可以非常方便。我们的目标是根据用户的偏好,让一切都能按比例放大和缩小。

  • 对于既爱固定布局又爱流体布局的设计师,弹性布局是完美的,因为它们各自的优点都可以在弹性布局中找到=

  • 理想状态是所有屏幕的高宽比和最初的设计高宽比一样,或者相差不多,完美适应 

缺点

  • 这种rem+js只不过是宽度自适应,高度没有做到自适应,一些对高度,或者元素间距要求比较高的设计,则这种布局没有太大的意义。如果只是宽度自适应,更推荐响应式设计。

综合结论

1.如果只做pc端,那么静态布局(定宽度)是最好的选择;

2.如果做移动端,且设计对高度和元素间距要求不高,那么弹性布局(rem+js)是最好的选择,一份css+一份js调节font-size搞定;

3.如果pc,移动要兼容,而且要求很高那么响应式布局还是最好的选择,前提是设计根据不同的高宽做不同的设计,响应式根据媒体查询做不同的布局。

参考

原文地址:https://www.cnblogs.com/kunmomo/p/11649893.html