私は少し前にコンテナスタイルのクエリに関するいくつかの初期の考えを書きました。まだ早い時期です。それらはすでに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です。その後、マッチング条件が見つかるまでバブルアップし続けます。 私の小さな脳が、スタイルに基づいて暗黙のコンテナを逃れることができる理由を理解するのは困難でしたが、サイズやインラインサイズなどの寸法クエリを扱っている場合はそれほどではありません。ミリアムはそれをうまく説明しています:
寸法クエリには、レイアウトループを防ぐために、コンテナのサイズ、レイアウト、およびスタイルにCSScontainment
が必要です。封じ込めは広く適用するための侵略的なものであるため、著者がどの要素がサイズの容器であるか(またはそうでない)を慎重に制御することが重要でした。スタイルベースのクエリには同じ制限がありません。 子孫スタイルでは、祖先の計算されたスタイルに影響を与えるための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 */ }
またはオペレーターは、織物を組み合わせて物事を乾燥させ続けることを許可しています: コンテナスタイルのクエリと、トグル()関数を定義するために行われている作業の間には少し重複があります。たとえば、イタリックと正常と言う2つのフォントスタイルの値を循環させることができます。
それは非常にクールで、スタイルのコンテナクエリが些細なものになる多くの作業もあります。
スタイルクエリとWebコンポーネント 次に、次のものを使用します。コンテナとしてホストの擬似要素を使用して、コンテナ名、コンテナタイプ、およびいくつかの高レベルの属性を設定します。
@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;
}
}
かっこいい。しかし、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生成コンテンツ
.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
以上がコンテナスタイルのクエリをより深く掘り下げますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

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

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

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

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

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

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

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

ドリームウィーバー CS6
ビジュアル Web 開発ツール

Dreamweaver Mac版
ビジュアル Web 開発ツール

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

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター
