2023 年每位前端开发者都应该知道的 6 个 CSS 代码段

强大且稳定的 CSS,可立即投入使用。

我认为,每位前端开发者都应了解如何使用容器查询、创建滚动贴靠体验、使用网格避免 position: absolute、快速敲定圆形、使用级联层,以及通过逻辑属性以更少的代码实现更多功能。下面简要介绍了每一条要求。

1. 容器查询

这项 CSS 功能连续 10 年都被用户评为最受欢迎的功能,现在在所有浏览器中都已稳定,您可以在 2023 年将其用于宽度查询。

.panel {
  container: layers-panel / inline-size;
}

.card {
  padding: 1rem;
}

@container layers-panel (min-width: 20rem) {
  .card {
    padding: 2rem;
  }
}
@container

浏览器支持

  • Chrome:105。
  • Edge:105.
  • Firefox:110。
  • Safari:16。

来源

container

浏览器支持

  • Chrome:105。
  • Edge:105.
  • Firefox:110.
  • Safari:16。

来源

2. 滚动捕捉

精心编排的滚动体验可让您的体验与众不同,滚动贴靠是匹配系统滚动用户体验并同时提供有意义的停止点的完美方式。

.snaps {
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  overscroll-behavior-x: contain;
}

.snap-target {
  scroll-snap-align: center;
}

.snap-force-stop {
  scroll-snap-stop: always;
}

如需详细了解此 CSS 功能的潜力,请观看这个庞大而鼓舞人心的 Codepen 集合(包含大约 25 个演示)。

scroll-snap-type

浏览器支持

  • Chrome:69.
  • Edge:79。
  • Firefox:99.
  • Safari:11.

来源

scroll-snap-align

浏览器支持

  • Chrome:69。
  • 边缘:79。
  • Firefox:68。
  • Safari:11.

来源

scroll-snap-stop

浏览器支持

  • Chrome:75.
  • 边缘:79。
  • Firefox:103.
  • Safari:15.

来源

overscroll-behavior

浏览器支持

  • Chrome:63.
  • Edge:18.
  • Firefox:59.
  • Safari:16。

来源

3. 网格堆

避免使用单单元格 CSS 网格进行绝对位置定位。当这些按钮堆叠在一起后,请使用“两端对齐”和“对齐”属性来确定它们的位置。

.pile {
  display: grid;
  place-content: center;
}

.pile > * {
  grid-area: 1/1;
}
grid

浏览器支持

  • Chrome:57。
  • Edge:16。
  • Firefox:52。
  • Safari:10.1。

来源

4. 快速圈

在 CSS 中创建圆形的方法有很多,但这绝对是最简洁的方法。

.circle {
  inline-size: 25ch;
  aspect-ratio: 1;
  border-radius: 50%;
}
aspect-ratio

浏览器支持

  • Chrome:88。
  • Edge:88.
  • Firefox:89.
  • Safari:15.

来源

5. 使用 @layer 控制变体

级联图层可以帮助将稍后发现或创建的变体插入到包含原始变体集的级联中的正确位置。

/* file buttons.css */
@layer components.buttons {
  .btn.primary {
    …
  }
}

然后,在某个完全不同的文件(在某个其他随机时间加载)中,将新变体附加到按钮层,就像它一直与其余变体一起存在一样。

/* file video-player.css */
@layer components.buttons {
  .btn.player-icon {
    …
  }
}
@layer

浏览器支持

  • Chrome:99。
  • Edge:99.
  • Firefox:97。
  • Safari:15.4。

来源

6. 使用逻辑属性,减少记忆内容,覆盖更多用户

记住这个一个新的盒模型再也不用担心为国际编写模式文档方向更改左右内边距或边距。将样式从实际属性调整为逻辑属性(例如 padding-inlinemargin-inlineinset-inline),现在浏览器将执行调整工作。

button {
  padding-inline: 2ch;
  padding-block: 1ch;
}

article > p {
  text-align: start;
  margin-block: 2ch;
}

.something::before {
  inset-inline: auto 0;
}
padding-inline

浏览器支持

  • Chrome:87.
  • Edge:87.
  • Firefox:66.
  • Safari:14.1。

来源

margin-block

浏览器支持

  • Chrome:87。
  • Edge:87.
  • Firefox:66.
  • Safari:14.1。

来源

inset-inline

浏览器支持

  • Chrome:87。
  • Edge:87.
  • Firefox:63。
  • Safari:14.1。

来源