CSSの新機能@scopeが便利すぎる! セレクタの適用範囲を設定できる、@scopeの基礎知識と使い方

CSSでこの機能を待ち望んでいた人もいると思います。
セレクタの適用範囲を設定できる@scopeがいよいよChromeでサポートされます。@scopeの基礎知識と使い方を紹介します。

たとえば、下記のHTMLにはimgが2つあります。@scopeを使用すると、1つ目の.media-object直下のimgにのみスタイルを適用できます。.content内のimgはターゲットにされません。

セレクタの適用範囲を設定できる、@scopeの基礎知識と使い方

A quick introduction to CSS @scope
by Bramus!

下記は各ポイントを意訳したものです。
※当ブログでの翻訳記事は、元サイト様にライセンスを得て翻訳しています。

はじめに

CSSの@scopeについてご存じですか?

@scopeはセレクタの範囲を設定するCSSの新しい機能で、中間要素に名前を付ける必要がなくなるため、BEMなどによる命名規則から離れることができます。

10月頭にリリース予定のChrome 118で実装される予定なので、@scopeの使い方を見てましょう。

CSS @scopeがなぜ必要なのか

@scopeがなぜ必要なのかその理由を示すことから始めます。
まずは、デモページをご覧ください。

See the Pen
✅ CSS Scoped Styles 1/4: Problem Statement
by coliss (@coliss)
on CodePen.

デモのHTMLは、下記の通りです。
親に.lightが設定されておりテキストリンクがあり、子に.darkとテキストリンクがあり、孫に.lightとテキストリンクがあります。

CSSは下記の通りです。

孫の3番目のテキストリンクのカラーに注目です。
デモをブラウザで表示すると、孫には.light a { color: red; }と設定されていますが、レッドではなく、イエローで表示されてしまいます。

サイトのキャプチャ

Chrome 116でキャプチャ

CSSカスケードの仕組み

イエローに表示されてしまうのは、CSSカスケードの仕組みによるものです。

使用されているセレクタは同じ詳細度を持つため、カスケードは「出現の順番(Order of Appearance」に進みます。そのため、.dark aが最終的に適用されます。そして、色は継承されるため、その入れ子になった.light内のテキストリンクもイエローになります。

CSSカスケードの仕組み

CSSカスケードの仕組み

CSS @scopeの基本的な使い方

CSSの@scopeを使用するとこの問題を簡単に解決できます。

CSSのスタイルルールのスコープに使用し、スコープルート(scope root)と各スタイルルール間にスコープの近接を適用します。

スコープルートは@scopeの括弧で囲まれた部分です。下記のCSSはで.light.darkです。

これが機能する理由は、スコープがカスケード内でステップ(Scope Proximity)を追加するからです。同じ詳細度の宣言は、ソースの順番に戻る前にスコープルートへの近接度によって重み付けされます。
クールだと思いませんか!🤩

CSSカスケードの仕組み

CSSカスケードの仕組み

@scopeを使用してデモを表示すると、.ligthは親も孫もレッドになり、.darkはイエローになります。これはもっとも近いスコープのルートを検索するからです。

サイトのキャプチャ

Chrome Canary 118でキャプチャ

@scopeのさらに優れた使い方

@scopeのさらに優れた点は、スコープの終点を設定して「ドーナツスコープ(donut scope)」を作成できることです。

@scopeブロック内のセレクタは、スコープの始点と終点の間の要素のみを対象とします。上記のCSSの場合、始点は.media-objectで、終点は.contentになります。

以下のHTMLと組み合わせると、CSSは.content内のimgはターゲットにされません。

これにより、ヘッダ画像に.media-object__header__imageなどの名前をつけていたBEMや複雑なセレクタを使用する手法から離れることができます。

@scopeを使用すると、そういった必要はなくなり、スコープの終点を使用してセレクタの範囲を切り離すだけです。

一つ重要な注意点があります。@scopeはセレクタの範囲を制限するものであり、継承を止めたり防いだりするものではないということです。

たとえば、ドーナツスコープ内のカラー宣言は、スコープの外側にあるツリーの奥の子にも継承されます。

CSSの@scopeChrome 118から実装予定で、10月に安定版がリリースされます。また、Chrome Canaryではすでに実装されています。

sponsors

top of page

©2025 coliss