你可能还不知道 CSS3 的 rem 字体大小

发布于 2021-11-03 21:10:20 字数 6083 浏览 1474 评论 0

在Web中使用什么 单位 来定义页面的字体大小,至今天为止都还在激烈的争论着,有人说 PX 做为单位好,有人说 EM 优点多,还有人在说 百分比 方便,以至于出现了 CSS Font-Size: em vs. px vs. pt vs. percent 这样的PK大局。不幸的是,仍然有不同的利弊,使各种技术都不太理想,但又无法不去用。真是进也难,退也难呀。

最近在学习 em 的相关知识的时候,无意之间让我拾得一宝,就是使用 rem 来设置Web页面的字体大小。让我一下子就来劲了,一口气看完并测试了一回,还真是爽歪歪的呀。师傅说好东西不能吃独食,于我就在这里给大家吹吹这个从没见过的 REM

在详细介绍 rem 之前,我们先一起来回顾一下我们常用的两种记量单位,也是备受争论的两个:

  1. PX为单位
  2. EM为单位

PX 为单位

在 Web 页面初期制作中,我们都是使用 px 来设置我们的文本,因为他比较稳定和精确。但是这种方法存在一个问题,当用户在浏览器中浏览我们制作的 Web 页面时,他改变了浏览器的字体大小,这时会使用我们的Web页面布局被打破。这样对于那些关心自己网站可用性的用户来说,就是一个大问题了。因此,这时就提出了使用 em 来定义 Web 页面的字体。

em 为单位

前面也说了,使用是 px 为单位是比较方便,而又一致,但在浏览器中放大或缩放浏览页面时会存在一个问题,要解决这个问题,我们可以使用 em 单位。Richard Rutter’在《How to size text using ems》一文中有做过详细的介绍,追至早一点,Richard Rutter 也在《How to Size Text in CSS》中进行过深入的剖析。

这种技术需要一个参考点,一般都是以 <body> 的 font-size 为基准。比如说我们使用 1em 等于 10px 来改变默认值 1em=16px,这样一来,我们设置字体大小相当于 14px 时,只需要将其值设置为 1.4em。

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

为什么 li 的 1.4em 是不是 14px 将是一个问号呢?如果你了解过 em 后,你会觉得这个问题是多问的。前面也简单的介绍过一回,在使用“em”作单位时,一定需要知道其父元素的设置,因为“em”就是一个相对值,而且是一个相对于父元素的值,其真正的计算公式是:

1 ÷ 父元素的 font-size × 需要转换的像素值 = em 值

这样的情况下 1.4em 可以是 14px,也可以是 20px,或者说是 24px,总之是一个不确定值,那么解决这样的问题,要么你知道其父元素的值,要么呢在任何子元素中都使用 1em。这样一来可能又不是我们所需要的方法。

这里我只是简单的介绍了一个这两个单位的使用,具体一点的大家可以参阅:

  1. Best Practices 的站长 Kyle 的《CSS Font-Size: em vs. px vs. pt vs. percent
  2. Converting px into percentage and em for relative CSS font sizes
  3. Em Vs Percent Widths
  4. CSS: Units of Measurement
  5. Jennifer KyrninUsing Points, Pixels, Ems, or Percentages for CSS Fonts

Rem 为单位

CSS3 的出现,他同时引进了一些新的单位,包括我们今天所说的rem。在W3C官网上是这样描述rem的——“font size of the root element” 。下面我们就一起来详细的了解 rem

前面说了 em 是相对于其父元素来设置字体大小的,这样就会存在一个问题,进行任何元素设置,都有可能需要知道他父元素的大小,在我们多次使用时,就会带来无法预知的错误风险。而 rem 是相对于根元素 <html>,这样就意味着,我们只需要在根元素确定一个参考值,在根元素中设置多大的字体,这完全可以根据您自己的需,大家也可以参考下图:

我们来看一个简单的代码实例:

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*/}

我在根元素 <html> 中定义了一个基本字体大小为 62.5%(也就是 10px。设置这个值主要方便计算,如果没有设置,将是以 16px 为基准 )。从上面的计算结果,我们使用 rem 就像使用 px 一样的方便,而且同时解决了 px 和 em 两者不同之处。

浏览器的兼容性

remCSS3新引进来的一个度量单位,大家心里肯定会觉得心灰意冷呀,担心浏览器的支持情况。其实大家不用害怕,你可能会惊讶,支持的浏览器还是蛮多的,比如:Mozilla Firefox 3.6+Apple Safari 5+Google ChromeIE9+Opera11+。只是可怜的IE6-8无法,你们就把他们当透明了吧,我向来都是如此。

不过使用单位设置字体,可不能完全不考虑IE了,如果你想使用这个REM,但也想兼容IE下的效果,可你可考虑“px”和“rem”一起使用,用”px”来实现IE6-8下的效果,然后使用 Rem 来实现代浏览器的效果。就让IE6-8不能随文字的改变而改变吧,谁让这个Ie6-8这么老呢?大家不仿试试,还蛮有意思,说不定这个就是主流的度量单位了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

落墨

暂无简介

文章
评论
796 人气
更多

推荐作者

微信用户

文章 0 评论 0

小情绪

文章 0 评论 0

ゞ记忆︶ㄣ

文章 0 评论 0

笨死的猪

文章 0 评论 0

彭明超

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文