尺码单位

CSS 播客 - 008:尺码单元

网络属于自适应媒介,但有时您需要控制其尺寸以提高界面的整体质量。限制行长度以提高可读性就是一个很好的例子。在网络这种灵活的媒介中,您如何做到这一点呢?

在这种情况下,您可以使用 ch 单位,它等于所渲染字体中以其计算大小显示的“0”字符的宽度。 此单位允许您使用专门设计文本大小的单位来限制文本的宽度,这样无论文本的大小如何,都可以实现可预测的控制。ch 单元是有助于满足特定上下文的少数单元之一,例如本例。

Numbers 表格

数字用于定义 opacityline-height,甚至是 rgb 中的颜色通道值。数字是无单位整数(1、2、3、100)和小数(0.1、0.2、0.3)。

数字的含义取决于它们的具体情境。 例如,在定义 line-height 时,如果您在没有支持单位的情况下定义,则数字代表比率:

p {
  font-size: 24px;
  line-height: 1.5;
}

在此示例中,1.5 等于 p 元素的计算像素字体大小150%。这意味着,如果 pfont-size24px,则行高将计算为 36px

数字也可以在以下位置使用:

  • 设置过滤条件的值时:filter: sepia(0.5) 会向元素应用 50% 深褐色滤镜。
  • 设置不透明度时:opacity: 0.5 会应用 50% 不透明度。
  • 在颜色通道中:rgb(50, 50, 50),可以使用值 0-255 设置颜色值。请参阅颜色课程
  • 转换元素:transform: scale(1.2) 会将元素大小按其初始大小的 120% 缩放。

百分比

在 CSS 中使用百分比时,您需要知道百分比的计算方式。 例如,width 的计算方式是占父元素可用宽度的百分比。

div {
  width: 300px;
  height: 100px;
}

div p {
  width: 50%; 
}

在上面的示例中,假设布局使用默认的 box-sizing: content-boxdiv p 的宽度为 150px

如果您将 marginpadding 设置为百分比,那么无论方向如何,它们都将成为父元素宽度的一部分。

div {
  width: 300px;
  height: 100px;
}

div p {
  margin-top: 50%; /* calculated: 150px */
  padding-left: 50%; /* calculated: 150px */
}

在上面的代码段中,margin-toppadding-left 将计算到 150px

div {
  width: 300px;
  height: 100px;
}

div p {
  width: 50%; /* calculated: 150px */
  transform: translateX(10%); /* calculated: 15px */
}

如果将 transform 值设为百分比,则该值取决于设置了转换的元素。在此示例中,ptranslateX 值为 10%width50%。首先,计算宽度:150px,因为它是其父级宽度的 50%。然后,取 150px10%,即 15px

尺寸和长度

如果您将单位附加到数字,它就会成为维度。 例如,1rem 就是一个维度。在这种情况下,数字与数字对应的单位在规范中称为“维度令牌”。 长度是表示距离的维度,可以是绝对的,也可以是相对的。

绝对长度

所有绝对长度均针对同一基底进行解析,因此无论在 CSS 中使用什么位置,它们都是可以预测的。例如,如果使用 cm 调整元素大小,然后输出,那么与标尺相比,结果应是准确的。

div {
  width: 10cm;
  height: 5cm;
  background: black;
}

如果您打印此页面,div 会输出为 10x5 厘米的黑色矩形。 请注意,CSS 不可用于数字内容,还用于打印内容的样式。 在设计印刷品时,绝对长度会非常有用。

单位 名称 等同于
厘米 厘米 1 厘米 = 96 像素/2.54
毫米 毫米 1 毫米 = 1 厘米的 1/10
问题 1/4 毫米 1Q = 1 厘米的 1/40
in 英寸 1 英寸 = 2.54 厘米 = 96 像素
pc 毕加语 1 个 = 1/6/1 英寸
得分 1 分 = 1 英寸的 1/72
像素 像素 1 px = 1 英寸的 1/96

相对长度

相对长度根据基本值计算得出,很像百分比。这些值和百分比之间的区别在于,您可以根据上下文调整元素的大小。这意味着 CSS 具有一些单位,例如以文本大小为基础的 ch,以及基于视口(浏览器窗口)宽度的 vw。由于其响应性,相对长度在网络上特别有用。

字体大小相对单位

CSS 提供了与所呈现排版元素大小相关的实用单位,例如文本本身的大小(em 单位)或字型字符的宽度(ch 单位)。

单位 相对于:
em 相对于字体大小,例如 1.5em 将比其父项计算出的基本字体大小大 50%。(过去都是大写字母“M”的高度)。
示例 使用启发法来确定是在元素当前计算出的字体大小中使用 x 高度、字母“x”还是“.5em”。
cap 元素当前计算出的字体大小中大写字母的高度。
ch 元素字体(以“0”字形表示)较窄字形的平均字符跳转
ic 元素字体中全宽字形的平均字符跳转,以“水”(以“水”字形,CJK 水表意文字,U+6C34)字形表示。
快速眼动 根元素的字体大小(默认为 16 像素)。
lh 元素的行高。
rlh 根元素的行高。
CSS 文本的效果是文本的 10 倍,带有分别代表升序高度、下出线高度和 x 高度的标签。x 高度表示 1ex,0 表示 1ch

视口相对单位

您可以使用视口(浏览器窗口)尺寸作为相对基准。这些单元划分了可用的视口空间。

单位 相对于
vw 视口宽度的 1%。用户可以使用此单元进行一些很酷的字体调整,例如根据页面宽度调整标题字体的大小,这样当用户调整大小时,字体也会随之调整大小。
vh 视口高度的 1%。 例如,如果您有页脚工具栏,则可以使用此参数来排列界面中的项目。
vi 根元素的内嵌轴占视口大小的 1%。 轴是指书写模式。在英语等水平书写模式下,内嵌轴是水平的。 在垂直书写模式(例如某些日语字体)中,内嵌轴从上到下运行。
vb 根元素的屏蔽轴占视口大小的 1%。 对于块轴,则是语言的方向性。英语等 LTR 语言会有一个垂直块轴,因为英语读者会从上到下解析页面。 垂直写入模式具有水平块轴。
vmin 视口较小尺寸的 1%。
vmax 视口较大尺寸的 1%。
div {
  width: 10vw;
}

p {
  max-width: 60ch;
}

在本例中,div 将是视口宽度的 10%,因为 1vw视口宽度的 1%p 元素的 max-width60ch,这意味着在计算的字体和大小中它不能超过 60 个“0”字符的宽度。

其他单位

还有一些其他指定单位已指定,用于处理特定类型的值。

角度单位

颜色模块中,我们了解了角度单位,它有助于定义度数值,例如 hsl 中的色相。它们还有助于在转换函数中旋转元素。

div {
  width: 150px;
  height: 150px;
  transform: rotate(60deg);
}

您可以使用 deg 角度单位将 div 在其中心轴上旋转 90°。

div {
  background-image: url('a-low-resolution-image.jpg');
}

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  div {
    background-image: url('a-high-resolution-image.jpg');
  }
}

分辨率单位

在前面的示例中,min-resolution 的值为 192dpidpi 单位表示每英寸的点数。一个有用的上下文是检测分辨率非常高的屏幕(例如媒体查询中的 Retina 显示屏),并提供分辨率更高的图片。

检查您的掌握程度

测试您对尺寸调整知识的掌握情况

以下哪些是有效的维度?

cm
厘米,是有效的绝对维度。
ui
界面不是 CSS 中的维度。
英寸
英寸,一个有效的绝对尺寸。
8 日
不是 CSS 维度
像素
像素,一个有效的绝对尺寸。
ch
字符单位,有效的相对维度。
ux
用户体验不是 CSS 中的一个维度。
em
字母“M”单位,一个有效的相对维度。
示例
字母“x”单位,一个有效的相对维度。

绝对单位和相对单位有何不同?

绝对值不能改变,但相对单位可以改变
绝对值可以改变,但计算基准的底数无法更改。
绝对长度根据单个共享基值计算,其中相对单位与可以更改的基值进行比较。
由于相对单位具有情境感知能力,因此其适应性更强、更灵活,但其对绝对单位的能力和可预测性是某些设计的基础。

视口单位是绝对的。

True
它们可能看起来是绝对的,但它们是相对于视口(可能是 iframe 或 WebView)而言,并不总是代表设备屏幕尺寸。
False
它们是相对于创建它们时所在的文档窗口而言的,可能和设备屏幕不同。

资源