Document: adoptedStyleSheets-Eigenschaft
Baseline 2023Newly available
Since March 2023, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Die adoptedStyleSheets
-Eigenschaft der Document
-Schnittstelle wird verwendet, um ein Array von konstruierten Stylesheets festzulegen, die vom Dokument verwendet werden sollen.
Hinweis:
Ein konstruiertes Stylesheet ist ein Stylesheet, das programmgesteuert mit dem CSSStyleSheet()
-Konstruktor erstellt wurde (im Vergleich zu einem, das von einem Benutzer-Agent beim Importieren eines Stylesheets aus einem Skript erstellt wurde, importiert mit <style>
und @import
, oder verlinkt über <link>
).
Die gleichen konstruierten Stylesheets können auch mit einer oder mehreren ShadowRoot
-Instanzen mittels der ShadowRoot.adoptedStyleSheets
-Eigenschaft geteilt werden. Änderungen an einem angenommenen Stylesheet wirken sich auf alle Objekte aus, die es angenommen haben.
Stylesheets in der Eigenschaft werden zusammen mit den anderen Stylesheets des Dokuments unter Verwendung des CSS-Cascade-Algorithmus ausgewertet. Wo die Auflösung von Regeln die Reihenfolge der Stylesheets berücksichtigt, wird angenommen, dass adoptedStyleSheets
nach denen in Document.styleSheets
geordnet sind.
Nur Stylesheets, die mithilfe des CSSStyleSheet()
-Konstruktors im Kontext des aktuellen Document
erstellt wurden, dürfen übernommen werden.
Wert
Der Wert ist ein Array von CSSStyleSheet
-Instanzen, die mit dem CSSStyleSheet()
-Konstruktor im Kontext desselben Document
erstellt worden sein müssen.
Wenn das Array geändert werden muss, verwenden Sie in-place Mutationen wie push()
. Die CSSStyleSheet
-Instanzen selbst können ebenfalls modifiziert werden, und diese Änderungen gelten überall dort, wo das Stylesheet übernommen wird.
In einer früheren Version der Spezifikation war das Array nicht modifizierbar, sodass der einzige Weg, neue Stylesheets hinzuzufügen, darin bestand, ein neues Array dem adoptedStyleSheets
zuzuweisen.
Ausnahmen
NotAllowedError
DOMException
-
Eine der
CSSStyleSheet
-Instanzen im Array wurde nicht mit demCSSStyleSheet()
-Konstruktor erstellt oder in einem anderen Dokument als dem aktuellen Dokument konstruiert, wie zum Beispiel in einem Frame.
Beispiele
Ein Stylesheet übernehmen
Der folgende Code zeigt ein Konstruktionsbeispiel eines Stylesheets, und dann wird CSSStyleSheet.replaceSync()
aufgerufen, um eine Regel zum Stylesheet hinzuzufügen. Das Stylesheet wird dann zu einem Array hinzugefügt und der adoptedStyleSheets
-Eigenschaft zugewiesen.
// Create an empty "constructed" stylesheet
const sheet = new CSSStyleSheet();
// Apply a rule to the sheet
sheet.replaceSync("a { color: red; }");
// Apply the stylesheet to a document
document.adoptedStyleSheets = [sheet];
Wir können eine neue Regel zum Stylesheet hinzufügen, indem wir CSSStyleSheet.insertRule()
verwenden.
sheet.insertRule("* { background-color: blue; }");
// The document will now have blue background.
Ein neues Stylesheet hinzufügen
Um ein ganz neues Stylesheet zur adoptedStyleSheets
-Eigenschaft hinzuzufügen, müssen wir ein neues kombiniertes Array erstellen und zuweisen. Dies wird unten mithilfe der Spread-Syntax demonstriert:
const extraSheet = new CSSStyleSheet();
extraSheet.replaceSync("p { color: green; }");
// Combine the existing sheets and new one
document.adoptedStyleSheets = [...document.adoptedStyleSheets, extraSheet];
Ein Stylesheet mit einem Shadow DOM teilen
Wir können ein Stylesheet auf ähnliche Weise zu einem Shadow Root teilen.
// Create an element in the document and then create a shadow root:
const node = document.createElement("div");
const shadow = node.attachShadow({ mode: "open" });
//Adopt the same sheet into the shadow DOM
shadow.adoptedStyleSheets = [sheet];
Spezifikationen
Specification |
---|
CSS Object Model (CSSOM) # dom-documentorshadowroot-adoptedstylesheets |
Browser-Kompatibilität
BCD tables only load in the browser