::Shadow と /deep/ の削除(Chrome 63)
bookmark_border bookmark
コレクションでコンテンツを整理
必要に応じて、コンテンツの保存と分類を行います。
Chrome 63 以降では、シャドウ ピアシング セレクタ ::shadow
と /deep/
を使用してシャドウルート内のコンテンツにスタイルを設定できなくなります。
/deep/
コンビネーターは子孫セレクタとして機能します。x-foo /deep/ div
は x-foo div
のように機能します。
::shadow
疑似要素はどの要素とも一致しません。
注: サイトが Polymer を使用している場合は、::shadow
と /deep/
から移行する手順をまとめた詳細なガイド を作成しました。 削除の判断
::shadow
と /deep/
は Chrome バージョン 45 で非推奨になりました。これは、2015 年 4 月のウェブ コンポーネント ミートアップ の参加者全員によって決定されました。
シャドウ ピアシング セレクタに関する主な懸念事項は、カプセル化に違反し、コンポーネントが内部実装を変更できなくなる状況が生じることです。
注: 現時点では、::shadow
と /deep/
は、querySelector()
や querySelectorAll()
などの JavaScript API で引き続き機能します。これらの API の継続的なサポートについては、GitHub で議論 されています。 CSS シャドウ パーツ の仕様は、シャドウ ピアス セレクタの代替として開発されています。シャドー パーツを使用すると、コンポーネント作成者は、カプセル化を維持しながら、名前付き要素を公開できます。また、ページ作成者は複数のプロパティを一度にスタイル設定できます。
サイトで ::shadow と /deep/ を使用している場合はどうすればよいですか?
::shadow
セレクタと /deep/
セレクタは、以前の Shadow DOM v0 コンポーネントにのみ影響します。Shadow DOM v1 を使用している場合は、サイトを変更する必要はありません。
Chrome Canary を使用して、これらの新しい変更によってサイトが破損していないことを確認できます。問題が発生した場合は、::shadow
と /deep/
の使用を削除してみてください。これらのセレクタの使用を削除するのが難しい場合は、ネイティブ シャドー DOM からシャドウ DOM ポリフィルに切り替えることを検討してください。この変更が必要なのは、サイトがネイティブ Shadow DOM v0 に依存している場合のみです。
削除の意向 |
Chromestatus トラッカー |
Chromium のバグ
特に記載のない限り、このページのコンテンツはクリエイティブ・コモンズの表示 4.0 ライセンス により使用許諾されます。コードサンプルは Apache 2.0 ライセンス により使用許諾されます。詳しくは、Google Developers サイトのポリシー をご覧ください。Java は Oracle および関連会社の登録商標です。
最終更新日 2017-10-24 UTC。
[[["わかりやすい","easyToUnderstand","thumb-up"],["問題の解決に役立った","solvedMyProblem","thumb-up"],["その他","otherUp","thumb-up"]],[["必要な情報がない","missingTheInformationINeed","thumb-down"],["複雑すぎる / 手順が多すぎる","tooComplicatedTooManySteps","thumb-down"],["最新ではない","outOfDate","thumb-down"],["翻訳に関する問題","translationIssue","thumb-down"],["サンプル / コードに問題がある","samplesCodeIssue","thumb-down"],["その他","otherDown","thumb-down"]],["最終更新日 2017-10-24 UTC。"],[],[]]