【CSS】浅谈CSS中常用的相对长度单位

简介: 【CSS】浅谈CSS中常用的相对长度单位

浅谈CSS中常用的相对长度单位

顾名思义,相对单位是根据与其他事物的关系来度量。所以,要注意到,所度量的实际距离,可能会因为不在其控制之下的其他因素而改变。如屏幕分辨率、可视区域的宽高等等。并且,对于某些相对单位,其大小会因使用该单位的元素的不同而不同。

em

CSS中,em 被定义为给定字体的font-size值。如果一个元素的font-size为14px,那么1em=14px。

但是,我们前面说到,相对单位的大小会因为使用该单位的元素的不同而不同。

示例:

h1,h2,p {
    margin-left:1em;
}

假设h1,h2,p的font-size大小分别为24px,18px,12px。

那么h1,h2,p的左外边距分别为24px,18px,12px。

如图所示:

它会继承父元素的font-size值。CSS属性line-height,font-size,margin-bottom和margin-top常具有一个用em表示的值。

rem

这个单位代表相对于根元素的 font-size 大小(例如

<html>元素的font-size)。当用在根元素的font-size上面时 ,它代表了它的初始值。

如示例:

px

像素可以从显示器这个角度理解。显示器是由一个一个小方块组成的网格,一个小方块是一个像素。如果我们将某个div的宽高均设置为30px,那么在这个div显示时,该div的宽高就会由相应多个显示器元素组成。

通常,我们可以使用像素表示图像的宽高,因为图像的宽高本身就是像素值。

那么有人会问,为什么px是相对单位呢?

在使用不同设备输出时,眼睛与设备输出的典型距离是不同的。比如电脑显示器,通常是一臂之距,而看书和纸张时(对应于打印机的设备输出),则通常会更近一些。看电视时则会更远。

因此,

参考像素:

  • 对于电脑显示器是0.26mm(即1/96英寸);
  • 对于激光打印机是0.20mm(假设阅读距离通常为55cm,即21英寸);

在CSS中,建议采用96ppi作为参考像素,这是windows机器常用的度量。

  • 对于屏幕显示,通常是一个设备像素(点)的显示。
  • 对于打印机和高分辨率的屏幕,一个CSS像素意味着多个设备像素,因此,每英寸的像素的数量保持在96左右。



相关文章
|
2月前
|
Web App开发 编解码 前端开发
告别固定字体大小:CSS使用相对单位提升网页可访问性和兼容性
在 Web 开发领域中,有很多误解流传,即使它们被反驳了很多次也仍然存在。"外部链接应该总是在新标签页中打开" 就是一个很好的例子。CSS Tricks 在将近十年前就对此进行了详细的解释(简而言之:大多数情况下是错误的),但它似乎仍然在某些角落中存在。
|
前端开发
15、CSS单位元素(px、em、rem)
15、CSS单位元素(px、em、rem)
58 0
15、CSS单位元素(px、em、rem)
|
前端开发
7、CSS定位(绝对、相对、固定)
7、CSS定位(绝对、相对、固定)
148 0
7、CSS定位(绝对、相对、固定)
|
编解码 前端开发 程序员
聊聊CSS里面的单位,别说你只会用px
聊聊CSS里面的单位,别说你只会用px
129 0
|
Web App开发 XML 编解码
01-CSS中的长度尺寸单位和颜色
01-CSS中的长度尺寸单位和颜色
197 0
01-CSS中的长度尺寸单位和颜色
|
前端开发
css单位%在不同属性中的依据计算
css单位%在不同属性中的依据计算
|
Web App开发 编解码 前端开发
扫盲 CSS 中的单位
在 CSS 中,对于尺寸属性的值一般可以分为以下几类:关键字、数值、百分比。关键字一般有 initial、unset 等,百分比则是相对值,常见的是相对于上级 BFC 元素的比例。当然还有包括纯数字值的如 line-height 可以为纯数字,本文主要讨论常见数值。
|
前端开发
#yyds干货盘点# 前端歌谣的刷题之路-第二十一题-css的单位二
#yyds干货盘点# 前端歌谣的刷题之路-第二十一题-css的单位二
55 0
#yyds干货盘点# 前端歌谣的刷题之路-第二十一题-css的单位二
|
前端开发
css:尺寸单位整理px、rem、em、vh、rpx
css:尺寸单位整理px、rem、em、vh、rpx
css:尺寸单位整理px、rem、em、vh、rpx
|
前端开发
#yyds干货盘点# 前端歌谣的刷题之路-第二十题-css的单位一
#yyds干货盘点# 前端歌谣的刷题之路-第二十题-css的单位一
78 0
#yyds干货盘点# 前端歌谣的刷题之路-第二十题-css的单位一