# 长度单位

  • 长度 <length> 用于表示距离尺寸的 CSS 数据类型。许多 CSS 属性会用到长度,比如 width、margin、padding。
  • 长度 <percentage> 表述一个百分比值。许多 CSS 属性 可以取百分比值,用以根据父对象来确定大小。百分比值由一个<number>具体数值后跟着%符号构成。就像其他在 css 里的单位一样,在%和数值之间是不允许有空格的。
名称 兼容性 描述
px
-
rpx
-
em
-
rem
-
cap
-
ch
-
cm
-
cqb
-
cqh
-
cqi
-
cqmax
-
cqmin
-
cqw
-
dvb
-
dvh
-
dvi
-
dvw
-
ex
-
ic
-
in
-
lh
-
lvb
-
lvh
-
lvi
-
lvw
-
mm
-
pc
-
pt
-
q
-
rcap
-
rch
-
rex
-
ric
-
rlh
-
svb
-
svh
-
svi
-
svw
-
vb
-
vh
-
vi
-
vmax
-
vmin
-
vw
-
%
app平台仅width、height、padding(-)、margin(-)、top、left、right、bottom、flex-basis等属性支持
fr
-

# rpx

rpx 是一个以设备750px为基准的单位,750rpx即为屏幕宽度,相当于100%;375rpx即为屏幕一半宽度,相当于50%。

因为很多设计稿是以750px为基准出图的,所以使用rpx可以比较好的在不同屏幕宽度下还原设计稿。

但是,机械的照搬设计图,是无法自适应不同宽度的屏幕的。尤其是pc宽屏、pad、折叠屏、横屏。

在移动互联网早期,手机屏幕宽度都差不多,rpx曾经广泛流行。但随着宽屏适配需求越来越强,rpx使用范围已经非常少了。

正确的屏幕适配做法是:使用 px + flex:1铺满剩余空间。确定清楚哪些是固定值,哪些是根据屏幕宽度和高度自动撑满,分别设置好px和flex:1

有些开发者误以为只有rpx才能在适配好大小屏幕,他们担心使用px,会在小屏幕上超级大。这个理解恰恰反了。

其实px不是物理像素,px也是逻辑像素。正常使用px,在所有屏幕上都有合适的大小。
比如不设置font-size时,text组件默认字号是16px,这个字号在各种大小的屏幕上都和OS系统默认字号大小接近。
设置了rpx,反而在大屏幕上,比如pad、折叠屏、横屏、pc宽屏上,字体显得特别的大。

除了宽屏适配问题,rpx的性能和精度也不如px,但优于百分比。

不管是rpx还是百分比单位,都需要在运行时计算,转换为实际的px才能渲染。

rpx需要根据屏幕宽度做一次计算转换;而百分比需要根据父容器的宽度做计算转换。屏幕宽度是固定的,取一次即可。父容器宽度的计算更复杂,所以百分比单位比rpx的转换逻辑更耗时。

所以推荐开发者尽量使用px。

  • 在需要根据屏幕宽度适应的场景,使用rpx
  • 在需要根据父容器宽度按百分比适应的场景,使用百分比

有些开发者,在font-size,height、padding、margin、边框、阴影,都在使用rpx。这是非常不推荐的行为,性能差且屏幕适配能力差。
rpx比较适合的场景是view的宽度width设置。

# 不同单位的差异

  • 长度默认值差异

    • App平台长度 <length> 可以不设置单位,不设置单位时当做 px 处理
    • Web平台长度 <length> 必须设置单位,不设置单位时当做无效值处理
      App平台允许设置纯数字是为了性能考虑,在需要频繁更改长度时,使用纯数字会比"数字+px"稍微快一点。
      日常开发为了更好的跨端兼容,还是推荐给长度 <length> 指定明确单位。
  • 单位精度差异

    • px、rpx属于逻辑像素,在不同dpi的设备上,需要转换为物理像素。当产生浮点数时,由于精度保留策略的不同,在不同浏览器和手机OS,可能造成细微的误差。
      尤其是浏览器对于小数点的px兼容不够好,比如0.5px很难正常显示。但app可以正常显示。
      另外rpx百分比,比px更容易产生浮点数,所以如果px能满足需求,尽量不用rpx和百分比
  • 性能差异

    • 性能 px > rpx > 百分比。rpx需要根据屏幕宽度换算为px,而百分比需要根据父容器的高或宽换算为px,计算复杂度高于rpx。

:::

# 字体大小单位

名称 兼容性 描述
px
-
rpx
-
em
app平台仅line-height属性支持
rem
-
cap
-
ch
-
cm
-
cqb
-
cqh
-
cqi
-
cqmax
-
cqmin
-
cqw
-
dvb
-
dvh
-
dvi
-
dvw
-
ex
-
ic
-
in
-
lh
-
lvb
-
lvh
-
lvi
-
lvw
-
mm
-
pc
-
pt
-
q
-
rcap
-
rch
-
rex
-
ric
-
rlh
-
svb
-
svh
-
svi
-
svw
-
vb
-
vh
-
vi
-
vmax
-
vmin
-
vw
-