EM和PX的关系

其中比较熟悉和经常使用的是px,其次便是em,而其他几种单位则不常使用,也不是设置显示文字大小好的选择。ptpc主要用于印刷制品的文字大小定义,一般出现在为印刷定义的样式中;em是相对单位,一般的1em=大写字母M的高度,且其具有继承性,可以继承父标签的属性;ex也是相对单位,一般的1ex=小写字母x的高度,很少使用。

据目前的情况来看,单位的选取主要集中在px,em和%上,普遍的观点是放弃使用px,使用em和%来定义文字大小。

为何放弃px?对于IE和IE内核的浏览器,客户端不能通过设置“文字大小”来改变页面文字大小,这一点就不符合“易用性”(Accessibility),在国内对这一点没有强制要求,可以自由定夺;但在法治相对健全的国家,像美国,就有相关的法案强制网站必须达到一定的易用性。因为不可能保证浏览网页的人都是“健全”的,有些人可能怀有影响阅读的疾病,比如近视,这时往往需要改变“文字大小”来协调阅读。

仅仅因为这一点而放弃易用的px确实有点冤枉,但对于逐渐人性化的发展趋势来说,这也是必要的;或者在IE8中可以通过设置“文字大小”而改变页面文字大小。这时便可以重新使用px了。

为何选择em和%?em和%都是相对单位,可以方便的在客户端进行设置而改变页面文字大小,从而达到了页面一定的“易用性”。

em为何物?上面也提到了,em是相对单位,em的初始值是1em=16px,为了能够方便的和px进行转换,常常在body中定义font-size为62.5%,这时1em=16px × 62.5%=10px,所以12px=1.2em,也就是在不考虑单位时,前者除以10即可。

我们需要怎么做?通过上面简单的说明,知道了在定义字体大小时,最好的选择时使用em和%作为单位,而放弃px的使用,那么具体要怎样做呢?

首先,为body定义字体大小,使用%:body{font-size:62.5%;}

其次,为其他标签定义字体大小,这时就需要用em,同时需要注意继承性。例如.entry无父类,其文字大小为1.2em(=12px),.entry p文字大小为1.2em,这时p中的文字大小就不是1.2×10=12px,而是1.2×1.2×10=14.4px。

我们需要做什么?看完本文后,如果您觉得有必要可以对你的站点进行文字大小的重定义,使用上面提到的方法;如果仍然使用px也无可厚非,毕竟很少有人通过客户端来设置字体大小,至少国内还没有相关条例强制要求。


### CSS中 `px`, `em`, `rem` 的区别及用法 #### 1. 定义特性 - **`px`**: 表示屏幕上的物理像素,是一种绝对单位。它的值不会随浏览器缩放或视口变化而改变[^2]。每个 `px` 对应显示设备的一个单一像素。 - **`em`**: 是一种相对长度单位,基于当前元素的父级字体大小计算。默认情况下,大多数浏览器设置的初始字体大小为 16px,因此未调整前 1em = 16px。通过修改 body 字体大小(如设为 62.5%),可以使 1em 转化为更易于管理的比例关系,即 1em10px[^1]。 - **`rem`**: 同样是相对长度单位,但它始终相对于根元素 `<html>` 的字体大小定义。无论嵌套层次如何,`rem` 不会受任何父级元素的影响,这使得它非常适合全局一致性的布局需求[^3]。 #### 2. 计算方式 - 如果 HTML 设置如下: ```css html { font-size: 16px; } div { font-size: 18px; } span { font-size: 1.5em; /* 相对于最近的父元素 */ } ``` 则 `<span>` 的实际字体大小将是 `1.5 * 18px = 27px`,因为 `em` 基于直接父级 `div` 的字体大小计算。 - 若改为使用 `rem`: ```css span { font-size: 1.5rem; /* 相对于根元素 <html> */ } ``` 此时 `<span>` 的字体大小则为 `1.5 * 16px = 24px`,独立于中间层 `div` 的设定。 #### 3. 使用场景 - **`px`**: - 当需要精确控制页面元素尺寸时适用。 - 如按钮宽度、图片高度等固定不变的设计细节。 - **`em`**: - 更适合局部范围内的比例调节,比如段落文字相对于标题字号缩小的情况。 - 或者构建动态适应不同分辨率的小型模块结构。 - **`rem`**: - 推荐用于整体网站框架搭建以及大型组件样式制定。 - 提供更好的可维护性一致性,在响应式网页设计中有显著优势[^4]。 ```css /* 示例代码展示三种单位的实际应用 */ /* 全局基础配置 */ html { font-size: 16px; /* 默认基准 */ } body { font-size: 62.5%; /* 修改后便于 em/px 换算 */ } /* 局部控件采用 px 实现精准定位 */ .button { width: 120px; height: 40px; } /* 文本内容利用 em 达成灵活适配 */ p { font-size: 1.2em; /* 等价于原生约 19.2px */ } h1 { font-size: 2em; /* 大小依据上下文环境自动调整 */ } /* 主题风格切换依靠 rem 维护统一标准 */ .container { padding: 2rem; /* 固定间距不依赖特定区域属性 */ } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值