すべてのフロントエンド デベロッパーが知っておくべき 6 つの CSS スニペット(2023 年)

ツールベルトにふさわしい、強力で安定した CSS を今すぐ使用できます。

すべてのフロントエンド デベロッパーは、コンテナ クエリの使用方法、スクロール スナップ エクスペリエンスの作成方法、グリッドを使用した position: absolute の回避方法、円の迅速な作成方法、カスケード レイヤの使用方法、論理プロパティを使用した少ないコードでのより多くの表現方法を理解しておくべきです。以下に、それぞれの概要を簡単に説明します。

1. コンテナクエリ

10 年連続で最も要望の多かった CSS 機能が、ブラウザ間で安定版となり、2023 年に幅のクエリで使用できるようになりました。

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

.card {
  padding: 1rem;
}

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

Browser Support

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

Source

container

Browser Support

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

Source

2. スクロール スナップ

スクロール エクスペリエンスをうまく調整すると、他のエクスペリエンスと差別化できます。スクロール スナップは、システム スクロール UX に合わせながら、意味のある停止ポイントを提供するための最適な方法です。

.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 機能の可能性については、約 25 個のデモを含む Codepen の大規模で刺激的なコレクションをご覧ください。

scroll-snap-type

Browser Support

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

Source

scroll-snap-align

Browser Support

  • Chrome: 69.
  • Edge: 79.
  • Firefox: 68.
  • Safari: 11.

Source

scroll-snap-stop

Browser Support

  • Chrome: 75.
  • Edge: 79.
  • Firefox: 103.
  • Safari: 15.

Source

overscroll-behavior

Browser Support

  • Chrome: 144.
  • Edge: 18.
  • Firefox: 150.
  • Safari: 16.

Source

3. グリッド パイル

単一のセル CSS グリッドで絶対位置を使用しないでください。重ねて配置したら、justify プロパティと align プロパティを使用して位置を調整します。

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

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

Browser Support

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

Source

4. クイック サークル

CSS で円を作成する方法はたくさんありますが、これは間違いなく最もシンプルな方法です。

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

Browser Support

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

Source

5. @layer を使用してバリエーションを制御する

カスケード レイヤは、後で検出または作成されたバリアントを、元のバリアントのセットとともにカスケードの適切な場所に挿入するのに役立ちます

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

その後、まったく別のファイルで、別のランダムなタイミングで読み込まれ、ボタンレイヤに新しいバリエーションが追加されます。まるで、最初から他のバリエーションと一緒に存在していたかのように。

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

Browser Support

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

Source

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

Browser Support

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

Source

margin-block

Browser Support

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

Source

inset-inline

Browser Support

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

Source