検索
ホームページウェブフロントエンドCSSチュートリアルコンテナスタイルのクエリをより深く掘り下げます

Digging Deeper Into Container Style Queries

私は少し前にコンテナスタイルのクエリに関するいくつかの初期の考えを書きました。まだ早い時期です。それらはすでにCSS封じ込めモジュールレベル3の仕様(現在編集者のドラフトステータス)で定義されていますが、まだいくつかの顕著な議論が行われています。

基本的なアイデアは、コンテナを定義してから、計算されたスタイリングに基づいてその子孫に条件付きでスタイルを適用できるということです。

私がこれまで見た中で最も良い例は、< em>< i>、< q>のようなものから斜体を削除することです。コンテンツが既にイタリック化されているコンテキストで使用されている場合:
@container <name>? <conditions> {
  /* conditional styles */
}</conditions></name>

それが一般的なアイデアです。しかし、あなたがそれを知らなかったなら、スペックの編集者であるミリアム・スザンヌは、公開されているコンテナスタイルのクエリに関する継続的かつ徹底的な個人ノートのセットを維持しています。先日更新され、スタイルクエリのより微妙な側面に頭を包み込もうとして、そこでしばらく時間を費やしました。それは非公式のものですが、私は私に際立っていたいくつかのことを書き留めると思いました。知るか?たぶんそれは私たちが最終的に楽しみにできるものです!
em, i, q {
  font-style: italic; /* default UA behavior */
}

/* When the container's font-style is italic, remove italics from these elements. */
@container style(font-style: italic) {
  em, i, q {
    font-style: normal;
  }
}

すべての要素はスタイルコンテナ

です

すべてがデフォルトでスタイルコンテナであるため、スタイルコンテナを定義するためにコンテナ名またはコンテナタイプを描写する必要さえありません。

では、イタリック体を削除する上記の例がありますか?コンテナが識別されないことに注意してください。 Style()関数を使用して、クエリにすぐにジャンプします。では、どのコンテナが照会されていますか?それは、適用されたスタイルを受信する要素

の直接の親になるでしょう。そうでなければ、それは

次の最も近い相対コンテナ

です。これは優先されます。 私はそれが好きです。クエリが試合を検索するのは非常にCSS-Yです。その後、マッチング条件が見つかるまでバブルアップし続けます。 私の小さな脳が、スタイルに基づいて暗黙のコンテナを逃れることができる理由を理解するのは困難でしたが、サイズやインラインサイズなどの寸法クエリを扱っている場合はそれほどではありません。ミリアムはそれをうまく説明しています:

寸法クエリには、レイアウトループを防ぐために、コンテナのサイズ、レイアウト、およびスタイルにCSS

containment

が必要です。封じ込めは広く適用するための侵略的なものであるため、著者がどの要素がサイズの容器であるか(またはそうでない)を慎重に制御することが重要でした。

スタイルベースのクエリには同じ制限がありません。 子孫スタイルでは、祖先の計算されたスタイルに影響を与えるためのCSSにはすでにありません。 (強調鉱山)

それはすべて結果に帰着します。そのうち、すべてが箱から出してスタイルクエリコンテナである限り、何もありません。 容器が見つかった場合:その容器に対して条件が解決されます。

複数のコンテナが一致する場合:最寄りの相対容器が優先されます。
  • 一致が見つからない場合:不明。
  • それは他のCSSと同じ「寛容」の精神です。
  • コンテナは、次元クエリとスタイルの両方のクエリをサポートできます

明示的なコンテナ名なしでスタイルクエリを定義したいとしましょう:

これは、すべての要素がスタイルコンテナ

であるため、コンテナタイプに関係なく機能するためです。それが、私たちが暗黙的にスタイルを照会し、最も近い試合に依存することを可能にするものです。そして、スタイルコンテナを確立する際に不利な副作用がないので、これはまったく問題ありません。

寸法クエリには明示的なコンテナタイプを使用する必要がありますが、すべての要素はスタイルクエリであるため、スタイルクエリではそれほど多くはありません。それはまた、このコンテナがスタイル
@container <name>? <conditions> {
  /* conditional styles */
}</conditions></name>

の両方のクエリの両方であることを意味します:

クエリから容器を除外します

おそらく、コンテナがマッチングプロセスに参加したくないでしょう。それは、コンテナタイプを設定することが可能かもしれません:要素になし。

明示的なスタイルクエリコンテナは、クエリの何が得られるかをより多くの制御を提供します
em, i, q {
  font-style: italic; /* default UA behavior */
}

/* When the container's font-style is italic, remove italics from these elements. */
@container style(font-style: italic) {
  em, i, q {
    font-style: normal;
  }
}

たとえば、パディングのスタイルクエリを書くことになった場合、明示的に指定されたコンテナまたは最寄りの直接親を使用しているかどうかにかかわらず、最適なマッチングコンテナを決定する信頼できる方法はありません。これは、パディングが継承されたプロパティではないためです。

したがって、そのような場合、コンテナ名を使用して、ブラウザに引​​用できるコンテナを明示的に通知する必要があります。コンテナに複数の明示的な名前を付けることもできます。

@container style(font-style: italic) {
  em {
    font-style: normal;
  }
}
ああ、コンテナ名は、コンテナのオプションと

再利用可能な

名前を任意の数を受け入れます!それは、マッチを検索するときにブラウザが選択できるようにすることに関して、さらに柔軟性があります。

1つの容器が渡された場合には、それが「フォールバック」とも見なされるのだろうか。

スタイルクエリを組み合わせることができます
.card-container {
  container: card / inline-size; /* implictly a style query container as well */
}

またはオペレーターは、織物を組み合わせて物事を乾燥させ続けることを許可しています:

@container <name>? <conditions> {
  /* conditional styles */
}</conditions></name>

スタイルの切り替え

コンテナスタイルのクエリと、トグル()関数を定義するために行われている作業の間には少し重複があります。たとえば、イタリックと正常と言う2つのフォントスタイルの値を循環させることができます。

em, i, q {
  font-style: italic; /* default UA behavior */
}

/* When the container's font-style is italic, remove italics from these elements. */
@container style(font-style: italic) {
  em, i, q {
    font-style: normal;
  }
}
かっこいい。しかし、CSSトグルの提案は、Toggle()関数がより単純なアプローチになることを示唆しています:

@container style(font-style: italic) {
  em {
    font-style: normal;
  }
}
しかし、この種のバイナリユースケースを超えたものは、golggle()がそれほど適していない場所です。ただし、スタイルクエリは行ってもいいです。ミリアムは、スタイルクエリがトグル()よりも適切である3つのインスタンスを識別します。

スタイルクエリは、「カスタムプロパティトグルハック」を解決します
.card-container {
  container: card / inline-size; /* implictly a style query container as well */
}

スタイルクエリは、「CSSカスタムプロパティトグルトリック」の正式なソリューションであることに注意してください。そこには、空のカスタムプロパティ( - フー:;)を設定し、カスタムプロパティが実際の値に設定されたときに、コンマ分離フォールバックメソッドを使用してオンとオフを「切り替える」ために使用します。

それは非常にクールで、スタイルのコンテナクエリが些細なものになる多くの作業もあります。

.some-element {
  container-type: none;
}
スタイルクエリとCSS生成コンテンツ

::前のコンテンツプロパティによって生成されたコンテンツの生成されたコンテンツの場合、::擬似要素の後、一致するコンテナはコンテンツが生成される要素です。

スタイルクエリとWebコンポーネント

.card {
  container-name: card layout theme;
}
Webコンポーネントをコンテナとして定義し、スタイルごとにクエリすることができます。まず、&lt; Template&gt;があります。コンポーネントの:

次に、次のものを使用します。コンテナとしてホストの擬似要素を使用して、コンテナ名、コンテナタイプ、およびいくつかの高レベルの属性を設定します。

.theme {
  container-name: theme;
}
.grid {
  container-name: layout;
}
.card {
  container-name: card layout theme;
}
&lt; Media-host&gt;の内部の要素&lt; Media-host&gt;のパラメーターを照会できます要素:

@container bubble style(--arrow-position: start start) or style(--arrow-position: end start) {
  .bubble::after {
    border-block-end-color: inherit;
    inset-block-end: 100%;
  }
}

/* is the same as... */
@container bubble style(--arrow-position: start start) {
  /* etc. */
}
@container bubble style(--arrow-position: end start) {
  /* etc. */
}
次は何ですか?

繰り返しますが、ここで私が書き留めたものはすべてミリアムのメモに基づいており、これらのメモは公式の仕様の代わりではありません。しかし、それらは議論されているものと、将来どこに着くことができるかを示しています。ミリアムは、私たちが従うことができる一握りの傑出した議論をリンクしてくれたことに感謝します。
em, i, q {
  font-style: italic;
}

@container style(font-style: italic) {
  em, i, q {
    font-style: normal;
  }
}
複数の宣言を制御する高レベルのカスタムプロパティ#5624

style()クエリは!重要なフラグを許可する必要がありますか? #7413

標準プロパティのスタイルクエリをレベル4に移動します#7185
  • AT-Rule Preludes#6966
  • をテストする機能を追加します

以上がコンテナスタイルのクエリをより深く掘り下げますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
CSSグリッドとは何ですか?CSSグリッドとは何ですか?Apr 30, 2025 pm 03:21 PM

CSSグリッドは、複雑で応答性の高いWebレイアウトを作成するための強力なツールです。設計を簡素化し、アクセシビリティを向上させ、古い方法よりも多くの制御を提供します。

CSS Flexboxとは何ですか?CSS Flexboxとは何ですか?Apr 30, 2025 pm 03:20 PM

記事では、レスポンシブデザインにおけるスペースの効率的なアラインメントと分布のためのレイアウト方法であるCSS FlexBoxについて説明します。 FlexBoxの使用量を説明し、CSSグリッドと比較し、ブラウザのサポートを詳細に説明します。

CSSを使用してWebサイトを応答するにはどうすればよいですか?CSSを使用してWebサイトを応答するにはどうすればよいですか?Apr 30, 2025 pm 03:19 PM

この記事では、ビューポートメタタグ、柔軟なグリッド、流体メディア、メディアクエリ、相対ユニットなど、CSSを使用してレスポンシブWebサイトを作成するための手法について説明します。また、CSSグリッドとフレックスボックスを使用してカバーし、CSSフレームワークを推奨しています

CSSボックスサイズのプロパティは何をしますか?CSSボックスサイズのプロパティは何をしますか?Apr 30, 2025 pm 03:18 PM

この記事では、要素の寸法の計算方法を制御するCSSボックスサイズのプロパティについて説明します。コンテンツボックス、ボーダーボックス、パディングボックスなどの値と、レイアウト設計とフォームアライメントへの影響について説明します。

CSSを使用してアニメーション化するにはどうすればよいですか?CSSを使用してアニメーション化するにはどうすればよいですか?Apr 30, 2025 pm 03:17 PM

記事では、CSS、キープロパティ、およびJavaScriptとの組み合わせを使用してアニメーションの作成について説明します。主な問題は、ブラウザの互換性です。

CSSを使用してプロジェクトに3D変換を追加できますか?CSSを使用してプロジェクトに3D変換を追加できますか?Apr 30, 2025 pm 03:16 PM

記事では、3D変換、主要なプロパティ、ブラウザの互換性、およびWebプロジェクトのパフォーマンスに関する考慮事項にCSSを使用して説明します。

CSSに勾配を追加するにはどうすればよいですか?CSSに勾配を追加するにはどうすればよいですか?Apr 30, 2025 pm 03:15 PM

この記事では、CSSグラデーション(線形、放射状、繰り返し)を使用して、ウェブサイトのビジュアルを強化し、深さ、フォーカス、および現代の美学を追加します。

CSSの擬似要素とは何ですか?CSSの擬似要素とは何ですか?Apr 30, 2025 pm 03:14 PM

記事では、CSSの擬似要素、HTMLスタイリングの強化における使用、および擬似クラスとの違いについて説明します。実用的な例を提供します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター