何时使用 Em 与 Rem
原文 http://www.w3cplus.com/css/when-to-use-em-vs-rem.html
你可能已经很熟练使用这两个灵活的单位,但你可能不完全了解何时使用rem,何时使用em。 本教程将帮你弄清楚!
em和rem都是相对单位,由浏览器转换为像素值,具体取决于您的设计中的字体大小设置。 如果你使用值1em或1rem,它可以被浏览器解析成 从16px到160px或其他任意值。
padding设置了1em
解析出来的值为16px
padding设置了1em
解析出来的值为160px
另一方面,浏览器使用px值,所以1px将始终显示为完全1px。
滑动滑块试试这个 CodePen 例子,你可以看到rem和em单位的值可以转化为不同的像素值,而px单位保持固定大小:
最大问题
使用em和rem单位可以让我们的设计更加灵活,能够控制元素整体放大缩小,而不是固定大小。 我们可以使用这种灵活性,使我们在开发期间,能更加快速灵活的调整,允许浏览器用户调整浏览器大小来达到最佳体验。
em和rem单位提供的这种灵活性和工作方式都很相似,所以最大的问题是,我们何时应使用em值,何时应使用rem值呢?
主要区别
em和rem单位之间的区别是浏览器根据谁来转化成px值 理解这种差异是决定何时使用哪个单元的关键。
我们要通过复习rem和em单位如何工作,来确保你知道每一个细节。 然后我会讲到为什么你应该使用em或rem的单位。
最后,我们会看看到底哪些典型元素的设计,你应该在实际应用中使用哪种类型的单位。
rem 单位如何转换为像素值
当使用rem单位,他们转化为像素大小取决于页根元素的字体大小,即html元素的字体大小。 根元素字体大小乘以你rem值。
例如,根元素的字体大小16px,10rem将等同于160px,即10 x 16 = 160。
CSS设置padding为10rem
浏览器解析出来的值为160px
em 单位如何转换为像素值
当使用em单位时,像素值将是em值乘以使用em单位的元素的字体大小。
例如,如果一个div有18px字体大小,10em将等同于180px,即10 × 18 = 180。
CSS设置padding为10em
浏览器解析出来的值为180px(或接近它)
重点理解:
有一个比较普遍的误解,认为em单位是相对于父元素的字体大小。 事实上,根据 W3标准 ,它们是相对于使用em单位的元素的字体大小。
父元素的字体大小可以影响em值,但这种情况的发生,纯粹是因为继承。 让我们看看为什么以及如何起作用。
Em 单位的继承效果
使用em单位存在继承的时候,情况会变得比较棘手,因为每个元素将自动继承其父元素的字体大小。 继承效果只能被明确的字体单位覆盖,比如px,vw。
使用em单位的元素字体大小根据它们来定。 但该元素可能继承其父元素的字体大小,而父元素又继承其父元素的字体大小,等等。 因此,以em为单位的元素字体大小可能会受到其任何父元素的字体大小影响。
让我们看看一个例子。 在下面的 CodePen 单步执行试试。 随着你的前进,使用 Chrome 开发工具或 Firebug 为火狐浏览器来检查我们的em单位计算到的像素值。
Em 继承的例子
如果我们的根元素字体大小为16px(通常是默认值) 一个子元素div里面padding值为1.5em,该div将从根元素继承字体大小16px。 因此padding会解析成24px,即1.5 x 16 = 24。
如果我们加多一个div来包裹原先的div,然后设置其字体大小为1.25em呢?
我们包裹的div继承根元素字体大小16px,并乘以它自己的1.25em的字体大小。 这将设置包裹div字体大小为20px,即1.25 x 16 = 20。
现在我们原始的div不再直接从根元素继承,而是从其新的父元素继承字体大小为20px 1.5em其padding值现在等于30px,即1.5 x 20 = 30。
这个继承效应可以更复杂,如果我们向我们原始的div添加em字体单位,比方说1.2em。
div从其父级继承20px字体大小,然后,乘以它自己的1.2em设置,给它24px,即1.2 × 20 = 24新字体大小。
div上1.5em的padding现在将再次改变大小,用新的字体大小,36px,即1.5 × 24 = 36。
最后,为了进一步说明那个em单位是相对于他们最终获得(不是父元素)的字体大小,让我们来看看设置padding: 1.5em如果我们显式设置div使用14px值,不继承字体大小会发生什么。
现在,我们的padding为21px,即1.5 x 14 = 21已经变小了。 它不受父元素的字体大小。
由于存在着这些隐患,你可以看到为什么必须知道如何正确管理使用em单位。
浏览器设置 HTML 元素字体大小的影响
默认情况下浏览器通常有字体大小16px,但这可以被用户更改为从9px到72px的任何值。
你需要知道的:
根html元素将继承浏览器中设置的字体大小,除非显式设置固定值去覆盖。
所以html元素的字体大小虽然是直接确定rem值,但字体大小可能首先来自浏览器设置。
因此浏览器的字体大小设置可以影响每个使用rem单元以及每个通过em单位继承的值。
没有设置 HTML 字体大小时,浏览器设置起作用
除非重写,否则它将继承浏览器默认设置的字体大小。 例如,让我们把网站的html元素没有设置font-size值。
如果用户让他们的浏览器默认字体大小为16px,那么根元素字体大小将为16px。 在 Chrome 开发工具下,你可以在已计算选项卡下看到一个元素继承的属性。
在这种情况下10rem等于160px,即10 x 16 = 160。
如果用户将其浏览器中的默认字体大小调为18px,根字体大小变成18px。 现在10rem转换为180px,即10 × 18 = 180。
浏览器将调整使用 em 单位的 HTML 元素字体大小
当em单位设置在html元素上时,它将转换为em值乘以浏览器字体大小的设置。
例如,如果网站的html元素的字体大小属性设置为1.25em,根元素字体大小将为1.25倍的浏览器的字体大小设置。
如果浏览器字体大小被设置为16px,根字体大小会出来为20px,即1.25 x 16 = 20。
在这种情况下10rem将等于200px,即10 × 20 = 200。
所以,如果浏览器字体大小被设置为20px,根元素字体大小会解析成25px,即1.25 × 20 = 25。
现在10rem将等于250px,即10 × 25 = 250。
总结 rem与 em 差异
上述所有归结如下:
- rem单位翻译为像素值是由html元素的字体大小决定的。 此字体大小会被浏览器中字体大小的设置影响,除非显式重写一个具体单位。
- em单位转为像素值,取决于他们使用的字体大小。 此字体大小受从父元素继承过来的字体大小,除非显式重写与一个具体单位。
为什么使用 rem 单位:
rem单位提供最伟大的力量并不仅仅是他们提供一致尺寸而不是继承。 相反,它给我们的一个途经去获取用户的偏好来影响网站中每一处使用rem的元素大小,不再是使用固定的px单位。
为此,使用rem单位的主要目的应该是确保无论用户如何设置自己的浏览器,我们的布局都能调整到合适大小。
一个站点最初设计可以专注于最常见的默认浏览器中字体大小16px。
使用浏览器默认字号16px
但是,通过使用rem单位,如果用户调整其字体大小,我们也能保证布局的完整性,使用较小的文本避免文本空间被压扁了。
浏览器解析的字号为34px。
如果用户缩小其字体大小,整个布局掉下来,空白区域中的文本也不会想得很无力。
浏览器字体大小 9px
用户会因为各种各样的原因更改字体大小设置。 容纳这些设置可以获得更好的用户体验。
重要的是:
一些设计师使用结合rem单位的方式给html元素设置了一个固定的px单位。 这是很普遍的做法,所以改变html元素的字体大小时,可以使整个页面做相应调整
我强烈反对种做法,因为它重写继承了用户设置的浏览器字体大小。 更夸张的说,这剥削了用户自行调整以获得最佳视觉效果的能力。
如果您确实需要更改 html 元素的字体大小,那么就使用em,rem单位,这样根元素的值还会是用户浏览器字体大小的乘积。
这将允许您通过更改您的html元素的字体大小,调整你的设计,但仍会保留用户的浏览器设置的效果。
为什么使用 em 单位
em单位取决于一个font-size值而非html元素的字体大小。
为此,em单位的主要目的应该是允许保持在一个特定的设计元素范围内的可扩展性。
例如,您可能使用em值设置导航菜单项的padding、margin,line-height等值。
带有0.9rem字体大小的菜单
通过这种方式,如果您更改菜单的字体大小菜单项周围的间距将在剩余的空间按比例缩放。
带有1.2rem字体大小的菜单
前面一节中你看到em单位如何变得不可收拾。 为此,我建议只在你标识清楚的情况下使用em单位。
实际应用
一些 Web 设计师之间存在辩论,我相信不同的人有不同的首选的方法,但我的建议是,如下所示。
使用 em 单位:
根据某个元素的字体大小做缩放而不是根元素的字体大小。
一般来说,你需要使用em单位的唯一原因是缩放没有默认字体大小的元素。
根据我们上面的例子,设计组件比如按钮,菜单和标题可能会有自己明确的字体大小。 当你修改字体大小的时候,你希望整个组件都适当缩放。
通用属性这一准则将适用于在非默认字体大小的元素上的padding、margin、width、height和line-height等值。
我建议,当您使用em单位,他们使用的元素的字体大小应设置对rem单位,以保留的可扩展性,但避免继承混淆。
通常不使用em单位控制字体大小
我们经常会看到使用em作为字体大小单位,特别是标题,当我认为如果使用rem将更具可扩展性。
标题经常使用em单位的原因是他们相比px单位,在相对常规文本大小方面更出色。 然而rem单位同样也可以实现这一目标。 如果html元素上任何字体大小调整,标题大小仍会缩放。
请尝试更改下面的 CodePen,看看html元素上的em字体大小如何起作用:
少部分情况下,我们不想我们的字体大小根据根元素做调整,只有几个例外的情况。
我们可以想到的例子是一个使用em字体大小的下拉菜单,我们有第二个级别的菜单项文本大小取决于第一级字体大小。 另一个例子可能是用在按钮里面的字体图标,字体图标的大小跟按钮的文本大小有关。
然而,大多数 Web 设计中的元素往往不会有这种类型的要求,所以一般使用rem单位的字体大小,em单位只在特殊的情况下使用。
使用 rem 单位:
不需要em单位,并且根据浏览器的字体大小设置缩放的任何尺寸。
这几乎在一个标准的设计中占据了一切,包括height,width,padding,margin,border,font-size,shadows,几乎包括你布局的每部分。
简单地说,一切可扩展都应该使用rem单位。
小技巧
创建布局时,往往要以像素为单位更方便,但部署时应使用rem单位。
你可以使用预处理比如 Stylus / Sass / Less , 来自动转换单位 或 PostCSS 之类的插件。
或者,您可以使用 PXtoEM 手动做您的转换。
始终使用 rem 单位做媒体查询
特别注意,当使用rem单位创建统一可扩展的设计,媒体查询也应该是rem单位。 这将确保,无论用户浏览器的字体大小,您的媒体查询会对它作出反应和调整您的布局。
例如,如果用户缩放文本非常高,您的布局可能需要从两列到单个列调整,因为它可能会在较小的移动设备上显示。
如果您的断点在固定的像素宽度,只有不同的视口的大小可以触发它们。 但是基于rem的断点他们将响应不同的字体大小。
不要使用 em 或 rem :
多列布局
布局中的列宽通常应该是%,因此他们可以流畅适应无法预知大小的视区。
然而单一列一般仍然应使用rem值来设置最大宽度。
例如:
.container { width: 100%; max-width: 75rem; }
这保持列的灵活,可扩展。又能防止变得太宽了。
当元素应该是严格不可缩放的时候
在一个典型的 Web 设计的过程中,不会有很多部分的你不能使用伸缩性设计的布局。 不过偶尔你会遇到真的需要使用显式的固定的值,以防止缩放的元素。
采用固定的尺寸值的前提应该是,如果被缩放的话,它的结构会被打碎。 这真的不常出现,所以你想拿出那些px单位之前,问问自己是否使用它们是绝对必要的。
总结
让我们以一个快速符号点概括我们介绍的内容:
- rem和em单位是由浏览器基于你的设计中的字体大小计算得到的像素值。
- em单位基于使用他们的元素的字体大小。
- rem单位基于html元素的字体大小。
- em单位可能受任何继承的父元素字体大小影响
- rem单位可以从浏览器字体设置中继承字体大小。
- 使用em单位应根据组件的字体大小而不是根元素的字体大小。
- 在不需要使用em单位,并且需要根据浏览器的字体大小设置缩放的情况下使用rem。
- 使用rem单位,除非你确定你需要em单位,包括对字体大小。
- 媒体查询中使用rem单位
- 不要在多列布局中使用em或rem,改用%。
- 不要使用em或rem,如果缩放会不可避免地导致要打破布局元素。
我希望你现在已经建立了强健的、 完整的图片,到底em和rem的单位如何工作,并通过,知道如何最好地利用他们在你的设计中。
我鼓励您尝试为你自己使用本教程指南,它们会为您创建完全成熟的可伸缩性和响应性布局。
本文根据 @Kezz Bracey 的《 Comprehensive Guide: When to Use Em vs. Rem 》所译,整个译文带有我们自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处:http://webdesign.tutsplus.com/tutorials/comprehensive-guide-when-to-use-em-vs-rem--cms-23984 。
何时使用 Em 与 Rem的更多相关文章
- 关于px、em和rem的学习笔记!
刚参加前端工作,字体一般使用px来设置大小,在处理响应式界面时对字体的大小变化处理感觉很吃力,得知对字体的大小有三种大小格式设置方式,便想一探究竟,希望可以有所帮助! px px像素(Pixel),相 ...
- css中单位px、pt、em和rem的区别
国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem,那么三者有什么区别,又各自有什么优劣呢? px :像素(Pixel).相对长度单位.像素px是相对于显示器屏幕分辨率而言的.(引自CSS ...
- px,em,rem
px:像素是相对于显示器屏幕分辨率而言的相对长度单位.pc端使用px倒也无所谓,可是在移动端,因为手机分辨率种类颇多,不可能一个个去适配,这时px就显得非常无力,所以就要考虑em和rem. em:继承 ...
- (转)px、em、rem的区别和使用
国内的设计师大都喜欢用px,而国外的网站大都喜欢用em和rem(国外的大部分网站能够调整的原因在于其使用了em或rem作为字体单位),那么三者有什么区别,又各自有什么优劣呢? 一.px特点 1. IE ...
- 深度讲解VIEWPORT和PX是什么?移动端单位px,em,rem
刚开始接触移动页面重构,是不是很迷惑应该按照多大的尺寸制作?320.640还是720?按照640的设计稿重构完页面,是不是还需要写其他尺寸来适配不同的屏幕大小?—— 这源于对viewport和px的不 ...
- 彻底弄懂响应式设计中的em和rem
前一阵子在响应式开发中遇到了em和rem的问题,也上网搜过一些文章,篇幅很长,也没有仔细看,今天来总结一下. rem是指:根元素(root element,html)的字体大小, em是指:父元素的字 ...
- px和em和rem的区别
一.px特点: 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的原因在于其使用了em或rem作为字体单位: 3. Firefox能够调整px和em,rem,但是96 ...
- css中的px、em、rem 详解
概念介绍: 1.px (pixel,像素):是一个虚拟长度单位,是计算机系统的数字化图像长度单位,如果px要换算成物理长度,需要指定精度DPI(Dots Per Inch,每英寸像素数),在扫描打印时 ...
- px、em、rem区别介绍
px.em.rem区别介绍 PX px像素(Pixel).相对长度单位.像素px是相对于显示器屏幕分辨率而言的. PX特点 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能 ...
- 移动端页面使用单位的问题:关于px、百分比、em、rem开发中逐渐转换的问题记录
开始写前端页面也有了快两年时间,从一开始的懵逼到现在的淡定,但是不能改变我还是一只小菜鸟的事实,平时遇到的一些问题都会记录在文件夹里,现在都整理一下大家一起分享自己平时也翻翻看看~ 不知道大家平时写的 ...
随机推荐
- cvc-elt.1: 找不到元素 'beans' 的声明
这次遇到的这个错误又坑爹又低级 , 是因为网上抄到了错误的xsd搞的. 这是网上抄到的 xsi:schemalocation=" http://www.springframework.org ...
- ylbtech-Unitity-CS-Arrays:数组
ylbtech-Unitity-CS-Arrays:数组 1.A,效果图返回顶部 1.B,源代码返回顶部 1.B.1, using System; class DeclareArraysSampl ...
- nyoj 95 众数问题
点击打开链接 众数问题 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 所谓众数,就是对于给定的含有N个元素的多重集合,每个元素在S中出现次数最多的成为该元素的重数, 多 ...
- (easy)LeetCode 226.Invert Binary Tree
Invert a binary tree. 4 / \ 2 7 / \ / \ 1 3 6 9 to 4 / \ 7 2 / \ / \ 9 6 3 1 Trivia:This problem was ...
- (easy)LeetCode 198.House Robber
You are a professional robber planning to rob houses along a street. Each house has a certain amount ...
- ASP.Net软件工程师基础(三)
1.多态 答: (1)虚方法 public class Child : Person { public void Speach() { base.Speach(); } public virtual ...
- 转载:LoadRunner11-遇到问题及解决办法
转自:http://4951507.blog.51cto.com/4941507/1108733 1.LoadRunner超时错误:在录制Web服务器端,如果超过120秒服务器协议脚本回放时超时情况经 ...
- Redis多机功能总结
1.通过Redis的复制功能,用户可以创建指定服务器的任意多个复制品,每个复制品服务器和被复制的原服务器拥有相同的数据: 2.通过将读请求分散给多个从服务器处理,用户可以减少主服务器在处理读请求方面的 ...
- Junit3
package code; public class MyCode { public int m1(){ System.out.println("数字型"); return 1; ...
- 【转】一个URL编码和解码的C++类
下面的代码实现了一个用于C++中转码的类strCoding.里面有UTF8.UNICODE.GB2312编码的互相转换. .H文件: #pragma once #include <iostrea ...