ホームページ ウェブフロントエンド CSSチュートリアル CSS `:not()` セレクターが Safari、Chrome、Firefox で異なる動作をするのはなぜですか?

CSS `:not()` セレクターが Safari、Chrome、Firefox で異なる動作をするのはなぜですか?

Dec 02, 2024 am 12:36 AM

Why Does the CSS `:not()` Selector Behave Differently in Safari, Chrome, and Firefox?

:not() Safari、Chrome、Firefox 間のセレクターの不一致

ブラウザーは多くの場合、さまざまな機能を備えた機能を実装しており、レンダリングの不一致につながります。 CSS :not() セレクターはそのようなケースの 1 つで、Safari、Chrome、Firefox 間で異なる動作を示します。

問題:

:not()引数に複数のレベルを指定すると、セレクターが期待どおりに動作しません。この例では:

em:not(div) {
    color: red
}
em:not(p div) {
    color: blue
}
ログイン後にコピー

Safari はテキストを青でレンダリングしますが、Chrome と Firefox は赤を使用します。

原因:

根本原因これは、Safari のレベル 4 :not() セレクターの最近の実装であり、複雑なセレクターを引数として使用できます。一方、Chrome と Firefox は、:not() の現在のバージョンでは単一レベルの引数のみをサポートします。

説明:

複雑なセレクターには複数の引数が含まれますコンビネータで区切られた複合セレクタ (子孫、兄弟など)。この場合、「p div」は、子孫コンビネータで区切られた 2 つの複合セレクタ (「p」と「div」) で構成される複雑なセレクタです。

期待される動作:

:not() のレベル 4 仕様に従って、セレクターは「em」要素に「blue」ルールを適用する必要があります。これは、「p」要素内にネストされているかどうかに関係なく、「div」要素内にありません。

現在のステータス:

Chrome とFirefox は最終的に新しい仕様を採用し、ブラウザー間で一貫した動作が実現される予定です。それまでは、開発者はこれらのブラウザで複数レベルの :not() セレクターを使用する場合、潜在的な不一致に注意する必要があります。

以上がCSS `:not()` セレクターが Safari、Chrome、Firefox で異なる動作をするのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

WordPressブロックと要素にボックスシャドウを追加します WordPressブロックと要素にボックスシャドウを追加します Mar 09, 2025 pm 12:53 PM

WordPressブロックと要素にボックスシャドウを追加します

Smart Forms Frameworkを使用してJavaScript連絡フォームを作成する Smart Forms Frameworkを使用してJavaScript連絡フォームを作成する Mar 07, 2025 am 11:33 AM

Smart Forms Frameworkを使用してJavaScript連絡フォームを作成する

満足している属性を持つインラインテキストエディターを作成します 満足している属性を持つインラインテキストエディターを作成します Mar 02, 2025 am 09:03 AM

満足している属性を持つインラインテキストエディターを作成します

GraphQLキャッシングの使用 GraphQLキャッシングの使用 Mar 19, 2025 am 09:36 AM

GraphQLキャッシングの使用

スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティス スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティス Mar 08, 2025 am 09:45 AM

スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティス

最初のカスタムSvelteトランジションを作成します 最初のカスタムSvelteトランジションを作成します Mar 15, 2025 am 11:08 AM

最初のカスタムSvelteトランジションを作成します

5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する 5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する Mar 04, 2025 am 10:22 AM

5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する

node.jsとexpressのMulterを使用してファイルアップロードします node.jsとexpressのMulterを使用してファイルアップロードします Mar 02, 2025 am 09:15 AM

node.jsとexpressのMulterを使用してファイルアップロードします

See all articles