1. Introduction
This document formally specifies the core features of the CSS Object Model (CSSOM). Other documents in the CSSOM family of specifications as well as other CSS related specifications define extensions to these core features.
The core features of the CSSOM are oriented towards providing basic capabilities to author-defined scripts to permit access to and manipulation of style related state information and processes.
The features defined below are fundamentally based on prior specifications of the W3C DOM Working Group, primarily [DOM]. The purposes of the present document are (1) to improve on that prior work by providing more technical specificity (so as to improve testability and interoperability), (2) to deprecate or remove certain less-widely implemented features no longer considered to be essential in this context, and (3) to newly specify certain extensions that have been or expected to be widely implemented.
2. Terminology
This specification employs certain terminology from the following documents: DOM, HTML, CSS Syntax, Encoding, URL, Fetch, Associating Style Sheets with XML documents and XML. [DOM] [HTML] [CSS3SYN] [ENCODING] [URL] [FETCH] [XML-STYLESHEET] [XML]
When this specification talks about object
A
where A
is actually an interface, it generally means an object implementing interface
A
.
The terms set and unset to refer to the true and false values of binary flags or variables, respectively. These terms are also used as verbs in which case they refer to mutating some value to make it true or false, respectively.
The term supported styling language refers to CSS.
Note: If another styling language becomes supported in user agents, this specification is expected to be updated as necessary.
The term supported CSS property refers to a CSS property that the user agent implements, including any vendor-prefixed properties, but excluding custom properties. A supported CSS property must be in its lowercase form for the purpose of comparisons in this specification.
In this specification the ::before and ::after pseudo-elements are assumed to exist for all elements even if no box is generated for them.
When a method or an attribute is said to call another method or attribute, the user agent must invoke its internal API for that attribute or method so that e.g. the author can’t change the behavior by overriding attributes or methods with custom properties or functions in ECMAScript.
Unless otherwise stated, string comparisons are done in a case-sensitive manner.
2.1. Common Serializing Idioms
To escape a character means to create a string of
"\
" (U+005C), followed by the character.
To escape a character as code point means to create a
string of "\
" (U+005C), followed by the Unicode code point as
the smallest possible number of hexadecimal digits in the range 0-9 a-f
(U+0030 to U+0039 and U+0061 to U+0066) to represent the code point in
base 16, followed by a single SPACE (U+0020).
To serialize an identifier means to create a string represented by the concatenation of, for each character of the identifier:
- If the character is NULL (U+0000), then the REPLACEMENT CHARACTER (U+FFFD).
- If the character is in the range [\1-\1f] (U+0001 to U+001F) or is U+007F, then the character escaped as code point.
- If the character is the first character and is in the range [0-9] (U+0030 to U+0039), then the character escaped as code point.
- If the character is the second character and is in the range [0-9]
(U+0030 to U+0039) and the first character is a "
-
" (U+002D), then the character escaped as code point. - If the character is the first character and is a "
-
" (U+002D), and there is no second character, then the escaped character. - If the character is not handled by one of the above rules and is
greater than or equal to U+0080, is "
-
" (U+002D) or "_
" (U+005F), or is in one of the ranges [0-9] (U+0030 to U+0039), [A-Z] (U+0041 to U+005A), or [a-z] (U+0061 to U+007A), then the character itself. - Otherwise, the escaped character.
-
Let s be an empty string.
-
Serialize an identifier from func’s name, ASCII lowercased, and append the result to s.
-
Append "(" (U+0028) to s.
-
Serialize func’s contents, either as specified by the definition of func, or in the shortest form possible (akin to the principles captured by serialize a CSS value). Append the result to s.
-
Append ")" (U+0029) to s.
-
Return s.
To serialize a string means to create a string represented by '"' (U+0022), followed by the result of applying the rules below to each character of the given string, followed by '"' (U+0022):
- If the character is NULL (U+0000), then the REPLACEMENT CHARACTER (U+FFFD).
- If the character is in the range [\1-\1f] (U+0001 to U+001F) or is U+007F, the character escaped as code point.
- If the character is '"' (U+0022) or "
\
" (U+005C), the escaped character. - Otherwise, the character itself.
Note: "'
" (U+0027) is not escaped because strings
are always serialized with '"' (U+0022).
To serialize a URL means to create a string represented by
"url(
", followed by the
serialization of the URL as a
string, followed by ")
".
To serialize a LOCAL means to create a string represented by
"local(
", followed by the
serialization of the LOCAL as a
string, followed by ")
".
To serialize a comma-separated list concatenate all items of
the list in list order while separating them by ",
", i.e.,
COMMA (U+002C) followed by a single SPACE (U+0020).
To serialize a whitespace-separated list concatenate all
items of the list in list order while separating them by "
", i.e.,
a single SPACE (U+0020).
Note: When serializing a list according to the above rules, extraneous whitespace is not inserted prior to the first item or subsequent to the last item. Unless otherwise specified, an empty list is serialized as the empty string.
3. CSSOMString
Most strings in CSSOM interfaces use the CSSOMString
type.
Each implementation chooses to define it as either USVString
or DOMString
:
typedef USVString CSSOMString ;
Or, alternatively:
typedef DOMString CSSOMString ;
DOMString
would preserve them,
whereas USVString
would replace them with U+FFFD REPLACEMENT CHARACTER.
This choice effectively allows implementations to do this replacement, but does not require it.
Using USVString
enables an implementation
to use UTF-8 internally to represent strings in memory.
Since well-formed UTF-8 specifically disallows surrogate code points,
it effectively requires this replacement.
On the other hand, implementations that internally represent strings as 16-bit code units might prefer to avoid the cost of doing this replacement.
4. Media Queries
Media queries are defined by [MEDIAQUERIES]. This section defines various concepts around media queries, including their API and serialization form.
4.1. Parsing Media Queries
To parse a media query list for a given string s into a media query list is defined in the Media Queries specification. Return the list of media queries that the algorithm defined there gives.
Note: A media query that ends up being "ignored" will turn
into "not all
".
To parse a media query for a given string s means to follow the parse a media query list steps and return null if more than one media query is returned or a media query if a single media query is returned.
Note: Again, a media query that ends up being "ignored" will
turn into "not all
".
4.2. Serializing Media Queries
To serialize a media query list run these steps:
- If the media query list is empty, then return the empty string.
- Serialize each media query in the list of media queries, in the same order as they appear in the media query list, and then serialize the list.
To serialize a media query let s be the empty string, run the steps below:
- If the media query is negated append "
not
", followed by a single SPACE (U+0020), to s. - Let type be the serialization as an identifier of the media type of the media query, converted to ASCII lowercase.
- If the media query does not contain media features append type, to s, then return s.
- If type is not "
all
" or if the media query is negated append type, followed by a single SPACE (U+0020), followed by "and
", followed by a single SPACE (U+0020), to s. -
Then, for each media feature:
- Append a "
(
" (U+0028), followed by the media feature name, converted to ASCII lowercase, to s. - If a value is given append a "
:
" (U+003A), followed by a single SPACE (U+0020), followed by the serialized media feature value, to s. - Append a "
)
" (U+0029) to s. - If this is not the last media feature append a single SPACE (U+0020),
followed by "
and
", followed by a single SPACE (U+0020), to s.
- Append a "
- Return s.
Input | Output |
---|---|
not screen and (min-WIDTH:5px) AND (max-width:40px) |
not screen and (min-width: 5px) and (max-width: 40px) |
all and (color) and (color) |
(color) and (color) |
4.2.1. Serializing Media Feature Values
This should probably be done in terms of mapping it to serializing CSS values as media features are defined in terms of CSS values after all.
To serialize a media feature value named v locate v in the first column of the table below and use the serialization format described in the second column:
Media Feature | Serialization |
---|---|
width | ... |
height | ... |
device-width | ... |
device-height | ... |
orientation |
If the value is portrait: "portrait ".
If the value is landscape: "landscape ".
|
aspect-ratio | ... |
device-aspect-ratio | ... |
color | ... |
color-index | ... |
monochrome | ... |
resolution | ... |
scan |
If the value is progressive: "progressive ".
If the value is interlace: "interlace ".
|
grid | ... |
Other specifications can extend this table and vendor-prefixed media features can have custom serialization formats as well.
4.3. Comparing Media Queries
To compare media queries m1 and m2 means to serialize them both and return true if they are a case-sensitive match and false if they are not.
4.4. The MediaList
Interface
An object that implements the MediaList
interface has an associated collection of media queries.
[Exposed =Window ]interface {
MediaList stringifier attribute [LegacyNullToEmptyString ]CSSOMString mediaText ;readonly attribute unsigned long length ;getter CSSOMString ?item (unsigned long );
index undefined appendMedium (CSSOMString );
medium undefined deleteMedium (CSSOMString ); };
medium
The object’s supported property indices are the numbers in the range zero to one less than the number of media queries in the collection of media queries represented by the collection. If there are no such media queries, then there are no supported property indices.
To create a MediaList
object with a string text, run the following steps:
- Create a new
MediaList
object. - Set its
mediaText
attribute to text. - Return the newly created
MediaList
object.
The mediaText
attribute, on getting, must return a
serialization of the collection of media queries.
Setting the mediaText
attribute must run these steps:
- Empty the collection of media queries.
- If the given value is the empty string, then return.
- Append all the media queries as a result of parsing the given value to the collection of media queries.
The item(index)
method must return a
serialization of the media query in the collection of media queries
given by index, or null, if index is greater than or equal to the number of media queries
in the collection of media queries.
The length
attribute must return the number of media queries in the collection of media
queries.
The appendMedium(medium)
method must run these steps:
- Let m be the result of parsing the given value.
- If m is null, then return.
- If comparing m with any of the media queries in the collection of media queries returns true, then return.
- Append m to the collection of media queries.
The deleteMedium(medium)
method must run these steps:
- Let m be the result of parsing the given value.
- If m is null, then return.
- Remove any media query from the collection of media queries for which
comparing the media query with m returns true.
If nothing was removed, then throw a
NotFoundError
exception.
5. Selectors
Selectors are defined in the Selectors specification. This section mainly defines how to serialize them.
5.1. Parsing Selectors
To
parse a group of selectors
means to parse the value using the selectors_group
production defined in the Selectors specification and return either a
group of selectors if parsing did not fail or null if parsing did
fail.
5.2. Serializing Selectors
To serialize a group of selectors serialize each selector in the group of selectors and then serialize a comma-separated list of these serializations.
To serialize a selector let s be the empty string, run the steps below for each part of the chain of the selector, and finally return s:
- If there is only one simple selector in the compound selectors which is a universal selector, append the result of serializing the universal selector to s.
- Otherwise, for each simple selector in the compound selectors that is not a universal selector of which the namespace prefix maps to a namespace that is not the default namespace serialize the simple selector and append the result to s.
- If this is not the last part of the chain of the selector append a
single SPACE (U+0020), followed by the combinator
"
>
", "+
", "~
", ">>
", "||
", as appropriate, followed by another single SPACE (U+0020) if the combinator was not whitespace, to s. - If this is the last part of the chain of the selector and there is
a pseudo-element, append "
::
" followed by the name of the pseudo-element, to s.
To serialize a simple selector let s be the empty string, run the steps below, and finally return s:
- type selector
- universal selector
-
- If the namespace prefix maps to a namespace that is
not the default namespace and is not the
null namespace (not in a namespace) append the
serialization of the
namespace prefix as an identifier, followed by a
"
|
" (U+007C) to s. - If the namespace prefix maps to a namespace that is
the null namespace (not in a namespace) append
"
|
" (U+007C) to s. - If this is a type selector append the serialization of the element name as an identifier to s.
- If this is a universal selector append "
*
" (U+002A) to s.
- If the namespace prefix maps to a namespace that is
not the default namespace and is not the
null namespace (not in a namespace) append the
serialization of the
namespace prefix as an identifier, followed by a
"
- attribute selector
-
- Append "
[
" (U+005B) to s. - If the namespace prefix maps to a namespace that is
not the null namespace (not in a namespace) append the
serialization of the
namespace prefix as an identifier, followed by a
"
|
" (U+007C) to s. - Append the serialization of the attribute name as an identifier to s.
- If there is an attribute value specified, append
"
=
", "~=
", "|=
", "^=
", "$=
", or "*=
" as appropriate (depending on the type of attribute selector), followed by the serialization of the attribute value as a string, to s. - If the attribute selector has the case-sensitivity flag present,
append "
i
" (U+0020 U+0069) to s. - Append "
]
" (U+005D) to s.
- Append "
- class selector
- Append a "
.
" (U+002E), followed by the serialization of the class name as an identifier to s. - ID selector
- Append a "
#
" (U+0023), followed by the serialization of the ID as an identifier to s. - pseudo-class
-
If the pseudo-class does not accept arguments append
"
:
" (U+003A), followed by the name of the pseudo-class, to s.Otherwise, append "
:
" (U+003A), followed by the name of the pseudo-class, followed by "(
" (U+0028), followed by the value of the pseudo-class argument(s) determined as per below, followed by ")
" (U+0029), to s.:lang()
- The serialization of a comma-separated list of each argument’s serialization as a string, preserving relative order.
:nth-child()
:nth-last-child()
:nth-of-type()
:nth-last-of-type()
- The result of serializing the value using the rules to serialize an <an+b> value.
:not()
- The result of serializing the value using the rules for serializing a group of selectors.
6. CSS
6.1. CSS Style Sheets
A CSS style sheet is an abstract concept that
represents a style sheet as defined by the CSS specification. In the CSSOM a
CSS style sheet is represented as a CSSStyleSheet
object.
CSSStyleSheet(options)
- When called, execute the steps to create a constructed CSSStyleSheet given options and return the result.
- To create a constructed
CSSStyleSheet
given -
- Construct a new
CSSStyleSheet
object sheet. - Set sheet’s location to the base URL of the associated Document for the current global object.
- Set sheet’s stylesheet base URL to the
baseURL
attribute value from options. - Set sheet’s parent CSS style sheet to null.
- Set sheet’s owner node to null.
- Set sheet’s owner CSS rule to null.
- Set sheet’s title to the empty string.
- Unset sheet’s alternate flag.
- Set sheet’s origin-clean flag.
- Set sheet’s constructed flag.
- Set sheet’s Constructor document to the associated Document for the current global object.
- If the
media
attribute of options is a string, create a MediaList object from the string and assign it as sheet’s media. Otherwise, serialize a media query list from the attribute and then create a MediaList object from the resulting string and set it as sheet’s media. - If the
disabled
attribute of options is true, set sheet’s disabled flag. - Return sheet.
- Construct a new
CSSStyleSheetInit
options, run these steps:
A CSS style sheet has a number of associated state items:
- type
- The literal string "
text/css
". - location
- Specified when created. The absolute-URL string of the first request of the CSS style sheet or null if the CSS style sheet was embedded. Does not change during the lifetime of the CSS style sheet.
- parent CSS style sheet
- Specified when created. The CSS style sheet that is the parent of the CSS style sheet or null if there is no associated parent.
- owner node
- Specified when created. The DOM node associated with the CSS style sheet or null if there is no associated DOM node.
- owner CSS rule
- Specified when created. The CSS rule in the parent CSS style sheet that caused the inclusion of the CSS style sheet or null if there is no associated rule.
- media
-
Specified when created. The
MediaList
object associated with the CSS style sheet.If this property is specified to a string, the media must be set to the return value of invoking create a
MediaList
object steps for that string.If this property is specified to an attribute of the owner node, the media must be set to the return value of invoking create a
MediaList
object steps for the value of that attribute. Whenever the attribute is set, changed or removed, the media’smediaText
attribute must be set to the new value of the attribute, or to null if the attribute is absent.Note: Changing the media’s
mediaText
attribute does not change the corresponding attribute on the owner node.Note: The owner node of a CSS style sheet, if non-null, is the node whose associated CSS style sheet is the CSS style sheet in question, when the CSS style sheet is added.
- title
-
Specified when created. The title of the CSS style sheet, which can be the empty string.
In the following, the title is non-empty for the first style sheet, but is empty for the second and third style sheets.
<style title="papaya whip"> body { background: #ffefd5; } </style>
<style title=""> body { background: orange; } </style>
<style> body { background: brown; } </style>
If this property is specified to an attribute of the owner node, the title must be set to the value of that attribute. Whenever the attribute is set, changed or removed, the title must be set to the new value of the attribute, or to the empty string if the attribute is absent.
Note: HTML only specifies title to be an attribute of the owner node if the node is in in a document tree.
- alternate flag
-
Specified when created. Either set or unset. Unset by default.
The following CSS style sheets have their alternate flag set:
<?xml-stylesheet alternate="yes" title="x" href="data:text/css,…"?>
<link rel="alternate stylesheet" title="x" href="data:text/css,…">
- disabled flag
-
Either set or unset. Unset by default.
Note: Even when unset it does not necessarily mean that the CSS style sheet is actually used for rendering.
- CSS rules
- The CSS rules associated with the CSS style sheet.
- origin-clean flag
- Specified when created. Either set or unset. If it is set, the API allows reading and modifying of the CSS rules.
- constructed flag
- Specified when created. Either set or unset. Unset by default. Signifies whether this stylesheet was created by invoking the IDL-defined constructor.
- disallow modification flag
- Either set or unset. Unset by default. If set, modification of the stylesheet’s rules is not allowed.
- constructor document
- Specified when created. The
Document
a constructed stylesheet is associated with. Null by default. Only non-null for stylesheets that have constructed flag set. - stylesheet base URL
- The base URL to use when resolving relative URLs in the stylesheet. Null by default. Only non-null for stylesheets that have constructed flag set.
6.1.1. The StyleSheet
Interface
The StyleSheet
interface represents an abstract, base style sheet.
[Exposed =Window ]interface {
StyleSheet readonly attribute CSSOMString type ;readonly attribute USVString ?href ;readonly attribute (Element or ProcessingInstruction )?ownerNode ;readonly attribute CSSStyleSheet ?parentStyleSheet ;readonly attribute DOMString ?title ; [SameObject ,PutForwards =mediaText ]readonly attribute MediaList media ;attribute boolean disabled ; };
The type
attribute must return the type.
The href
attribute must return the location.
The ownerNode
attribute must return the owner node.
The parentStyleSheet
attribute must return the
parent CSS style sheet.
The title
attribute must return the title or null if
title is the empty string.
The media
attribute must return the media.
The disabled
attribute, on getting, must return true if the
disabled flag
is set, or false otherwise. On setting, the disabled
attribute must set the
disabled flag if the new value is true, or unset the
disabled flag otherwise.
6.1.2. The CSSStyleSheet
Interface
The CSSStyleSheet
interface represents a CSS style sheet.
[Exposed =Window ]interface :
CSSStyleSheet StyleSheet {constructor (optional CSSStyleSheetInit = {});
options readonly attribute CSSRule ?ownerRule ; [SameObject ]readonly attribute CSSRuleList cssRules ;unsigned long insertRule (CSSOMString ,
rule optional unsigned long = 0);
index undefined deleteRule (unsigned long );
index Promise <CSSStyleSheet >replace (USVString );
text undefined replaceSync (USVString ); };
text dictionary {
CSSStyleSheetInit DOMString =
baseURL null ; (MediaList or DOMString )= "";
media boolean =
disabled false ; };
The ownerRule
attribute must return the owner CSS rule.
If a value other than null is ever returned, then that same value must always be returned on each get access.
The cssRules
attribute must follow these steps:
- If the origin-clean flag is unset,
throw a
SecurityError
exception. -
Return a read-only, live
CSSRuleList
object representing the CSS rules.Note: Even though the returned
CSSRuleList
object is read-only (from the perspective of client-authored script), it can nevertheless change over time due to its liveness status. For example, invoking theinsertRule()
ordeleteRule()
methods can result in mutations reflected in the returned object.
The insertRule(rule, index)
method must run the following steps:
- If the origin-clean flag is unset,
throw a
SecurityError
exception. - If the disallow modification flag is set, throw a
NotAllowedError
DOMException
. - Let parsed rule be the return value of invoking parse a rule with rule.
- If parsed rule is a syntax error, throw a
SyntaxError
DOMException
. - If parsed rule is an @import rule, and the constructed flag is set, throw
a
SyntaxError
DOMException
. - Return the result of invoking insert a CSS rule rule in the CSS rules at index.
The deleteRule(index)
method must run the following steps:
- If the origin-clean flag is unset,
throw a
SecurityError
exception. - If the disallow modification flag is set, throw a
NotAllowedError
DOMException
. - Remove a CSS rule in the CSS rules at index.
The replace(text)
method must run the following steps:
- Let promise be a promise.
- If the constructed flag is not set, or the disallow modification flag is set, reject promise with a
NotAllowedError
DOMException
and return promise. - Set the disallow modification flag.
-
In parallel, do these steps:
- Let rules be the result of running parse a stylesheet’s contents from text.
- If rules contains one or more @import rules, remove those rules from rules.
- Set sheet’s CSS rules to rules.
- Unset sheet’s disallow modification flag.
- Resolve promise with sheet.
- Return promise.
The replaceSync(text)
method must run the
steps to synchronously replace the rules of a CSSStyleSheet on this CSSStyleSheet
given text.
To synchronously replace the rules of a CSSStyleSheet on sheet given text, run these steps:
- If the constructed flag is not set, or the disallow modification flag is set, throw a
NotAllowedError
DOMException
. - Let rules be the result of running parse a stylesheet’s contents from text.
- If rules contains one or more @import rules, remove those rules from rules.
- Set sheet’s CSS rules to rules.
6.1.2.1. Deprecated CSSStyleSheet members
Note: These members are required for compatibility with existing sites.
partial interface CSSStyleSheet { [SameObject ]readonly attribute CSSRuleList rules ;long addRule (optional DOMString = "undefined",
selector optional DOMString = "undefined",
style optional unsigned long );
index undefined removeRule (optional unsigned long = 0); };
index
The rules
attribute must follow the same steps as cssRules
, and return the same object cssRules
would return.
The removeRule(index)
method must run the same steps as deleteRule()
.
The addRule(selector, block, optionalIndex)
method must run the following steps:
- Let rule be an empty string.
- Append selector to rule.
- Append
" { "
to rule. - If block is not empty, append block, followed by a space, to rule.
- Append
"}"
to rule - Let index be optionalIndex if provided, or the number of CSS rules in the stylesheet otherwise.
- Call
insertRule()
, with rule and index as arguments. - Return
-1
.
Authors should not use these members
and should instead use and teach the standard CSSStyleSheet
interface defined earlier,
which is consistent with CSSGroupingRule
.
6.2. CSS Style Sheet Collections
Below various new concepts are defined that are associated with each
DocumentOrShadowRoot
object.
Each DocumentOrShadowRoot
has an associated list of zero or more CSS style sheets, named the
document or shadow root CSS style sheets. This is
an ordered list that contains:
- Any CSS style sheets created from HTTP
Link
headers, in header order - Any CSS style sheets associated with the
DocumentOrShadowRoot
, in tree order
Each DocumentOrShadowRoot
has an associated list of zero or more CSS style sheets, named the
final CSS style sheets. This is
an ordered list that contains:
- The document or shadow root CSS style sheets.
- The contents of
DocumentOrShadowRoot
’sadoptedStyleSheets
' backing list, in array order.
To create a CSS style sheet, run these steps:
- Create a new CSS style sheet object and set its properties as specified.
-
Then run the add a CSS style sheet steps for the newly created CSS style sheet.
If the origin-clean flag is unset, this can expose information from the user’s intranet.
To add a CSS style sheet, run these steps:
- Add the CSS style sheet to the list of document or shadow root CSS style sheets at the appropriate location.
-
If the CSS style sheet’s owner node contributes a script-blocking style sheet, then user agents must append the owner node to its node document’s script-blocking style sheet set.
The remainder of these steps deal with the disabled flag.
- If the disabled flag is set, then return.
- If the title is not the empty string, the alternate flag is unset, and preferred CSS style sheet set name is the empty string change the preferred CSS style sheet set name to the title.
-
If any of the following is true, then unset the
disabled flag and return:
- The title is the empty string.
- The last CSS style sheet set name is null and the title is a case-sensitive match for the preferred CSS style sheet set name.
- The title is a case-sensitive match for the last CSS style sheet set name.
- Set the disabled flag.
To remove a CSS style sheet, run these steps:
- Remove the CSS style sheet from the list of document or shadow root CSS style sheets.
- Set the CSS style sheet’s parent CSS style sheet, owner node and owner CSS rule to null.
A persistent CSS style sheet is a CSS style sheet from the document or shadow root CSS style sheets whose title is the empty string and whose alternate flag is unset.
A CSS style sheet set is an ordered collection of one or more CSS style sheets from the document or shadow root CSS style sheets which have an identical title that is not the empty string.
A CSS style sheet set name is the title the CSS style sheet set has in common.
An enabled CSS style sheet set is a CSS style sheet set of which each CSS style sheet has its disabled flag unset.
To enable a CSS style sheet set with name name, run these steps:
- If name is the empty string, set the disabled flag for each CSS style sheet that is in a CSS style sheet set and return.
- Unset the disabled flag for each CSS style sheet in a CSS style sheet set whose CSS style sheet set name is a case-sensitive match for name and set it for all other CSS style sheets in a CSS style sheet set.
To select a CSS style sheet set with name name, run these steps:
- enable a CSS style sheet set with name name.
- Set last CSS style sheet set name to name.
A last CSS style sheet set name is a concept to determine what CSS style sheet set was last selected. Initially its value is null.
A preferred CSS style sheet set name is a concept to determine which CSS style sheets need to have their disabled flag unset. Initially its value is the empty string.
To change the preferred CSS style sheet set name with name name, run these steps:
- Let current be the preferred CSS style sheet set name.
- Set preferred CSS style sheet set name to name.
- If name is not a case-sensitive match for current and last CSS style sheet set name is null enable a CSS style sheet set with name name.
6.2.1. The HTTP Default-Style Header
The HTTP Default-Style header can be used to set the preferred CSS style sheet set name influencing which CSS style sheet set is (initially) the enabled CSS style sheet set.
For each HTTP Default-Style header, in header order, the user agent must change the preferred CSS style sheet set name with name being the value of the header.
6.2.2. The StyleSheetList
Interface
The StyleSheetList
interface represents an ordered collection of CSS style sheets.
[Exposed =Window ]interface {
StyleSheetList getter CSSStyleSheet ?item (unsigned long );
index readonly attribute unsigned long length ; };
The object’s supported property indices are the numbers in the range zero to one less than the number of CSS style sheets represented by the collection. If there are no such CSS style sheets, then there are no supported property indices.
The item(index)
method must return the indexth CSS style
sheet in the collection. If there is no indexth object in the collection, then the method must return null.
The length
attribute must return the number of CSS style sheets
represented by the collection.
6.2.3. Extensions to the DocumentOrShadowRoot
Interface Mixin
partial interface mixin DocumentOrShadowRoot { [SameObject ]readonly attribute StyleSheetList styleSheets ;attribute ObservableArray <CSSStyleSheet >adoptedStyleSheets ; };
The styleSheets
attribute must return a StyleSheetList
collection representing
the document or shadow root CSS style sheets.
The set an indexed value algorithm for
adoptedStyleSheets
, given value and index,
is the following:
- If value’s constructed flag is not set, or its constructor document is not equal to this
DocumentOrShadowRoot
’s node document, throw a "NotAllowedError
"DOMException
.
6.3. Style Sheet Association
This section defines the interface an
owner node of a CSS style sheet has to
implement and defines the requirements for
xml-stylesheet processing instructions
and HTTP Link
headers when the link
relation type is an
ASCII case-insensitive match for
"stylesheet
".
6.3.1. Fetching CSS style sheets
- Let origin be document’s origin.
- Let request be a new request, with the url parsed URL, origin origin, referrer referrer, and if specified the set of parameters parameters.
-
Fetch request,
with processResponseEndOfBody, given response,
being the following steps:
- If response is a network error, return.
- If document is in quirks mode, response is
CORS-same-origin and the Content-Type metadata of response is not a
supported styling language change the Content-Type metadata of response to
text/css
. - If response is not in a supported styling language, return.
- Execute processTheResponse given response
6.3.2. The LinkStyle
Interface
The associated CSS style sheet of a node is the CSS style sheet in the list of
document or shadow root CSS style sheets of which the owner node is said node.
This node must also implement the LinkStyle
interface.
interface mixin {
LinkStyle readonly attribute CSSStyleSheet ?sheet ; };
The sheet
attribute must return the associated CSS style sheet for the node or null
if there is no associated CSS style sheet.
style
element has a sheet
attribute that returns a
StyleSheet
object representing the style sheet, but for
the second style
element, the sheet
attribute returns null,
assuming the user agent supports CSS (text/css
), but does
not support the (hypothetical) ExampleSheets (text/example-sheets
).
<style type="text/css"> body { background:lime } </style>
<style type="text/example-sheets"> $(body).background := lime </style>
Note: Whether or not the node refers to a style sheet is defined by the specification that defines the semantics of said node.
6.3.3. Requirements on specifications
Specifications introducing new ways of associating style sheets through
the DOM should define which nodes implement the
LinkStyle
interface. When doing so, they
must also define when a CSS style sheet is
created.
6.3.4. Requirements on user agents Implementing the xml-stylesheet processing instruction
ProcessingInstruction includes LinkStyle ;
The prolog refers to nodes that are children of the
Document
and are not following the
Element
child of the Document
, if any.
ProcessingInstruction
node node becomes part of the
prolog, is no longer part of the prolog, or has its data changed, these steps
must be run:
- If an instance of this algorithm is currently running for node, abort that instance, and stop the associated fetching if applicable.
- If node has an associated CSS style sheet, remove it.
- If node is not an xml-stylesheet processing instruction, then return.
- If node does not have an
href
pseudo-attribute, then return. - Let title be the value of the
title
pseudo-attribute or the empty string if thetitle
pseudo-attribute is not specified. - If there is an
alternate
pseudo-attribute whose value is a case-sensitive match for "yes
" and title is the empty string, then return. - If there is a
type
pseudo-attribute whose value is not a supported styling language the user agent may return. - Let input URL be the value specified by the
href
pseudo-attribute. - Let document be node’s node document
- Let base URL be document’s document base URL.
- Let referrer be document’s address.
- Let parsed URL be the return value of invoking the URL parser with the string input URL and the base URL base URL.
- If parsed URL is failure, then return.
-
Fetch a CSS style sheet
with parsed URL parsed URL,
referrer referrer,
document document,
and processTheResponse given response being the following steps:
-
Create a CSS style sheet with the following properties:
- location
- The result of invoking the URL serializer with parsed URL.
- parent CSS style sheet
- null.
- owner node
- node.
- owner CSS rule
- null.
- media
- The value of the
media
pseudo-attribute if any, or the empty string otherwise. - title
- title.
- alternate flag
- Set if the
alternate
pseudo-attribute value is a case-sensitive match for "yes
", or unset otherwise. - origin-clean flag
- Set if response is CORS-same-origin, or unset otherwise.
The CSS environment encoding is the result of running the following steps:
- If the element has a
charset
pseudo-attribute, get an encoding from that pseudo-attribute’s value. If that succeeds, return the resulting encoding and abort these steps. - Otherwise, return the document’s character encoding. [DOM]
-
Create a CSS style sheet with the following properties:
6.3.5. Requirements on user agents Implementing the HTTP Link Header
For each HTTP Link
header of which one
of the link relation types is an
ASCII case-insensitive match
for "stylesheet
" these steps
must be run:
- Let title be the value of the first of all the
title
parameters. If there are no such parameters it is the empty string. - If one of the (other) link relation types is an
ASCII case-insensitive match for
"
alternate
" and title is the empty string, then return. - Let input URL be the value specified.
- Let base URL be the document’s document base URL.
- Let referrer be the document’s address.
- Let parsed URL be the return value of invoking the URL parser with the string input URL and the base URL base URL.
- If parsed URL is failure, then return.
-
Fetch a CSS style sheet
with parsed URL parsed URL,
referrer referrer,
document being the document,
and processTheResponse, given response, being the following steps:
What if the HTML parser hasn’t decided on quirks/non-quirks yet?
-
Create a CSS style sheet with the following properties:
- location
- The result of invoking the URL serializer with parsed URL.
- owner node
- null.
- parent CSS style sheet
- null.
- owner CSS rule
- null.
- media
- The value of the first
media
parameter. - title
- title.
- alternate flag
- Set if one of the specified link relation type for this HTTP
Link
header is an ASCII case-insensitive match for "alternate
", or false otherwise. - origin-clean flag
- Set if response is CORS-same-origin, or unset otherwise.
-
Create a CSS style sheet with the following properties:
A style sheet referenced by a HTTP Link
header using the rules in this section is said to be a style sheet
that is blocking scripts if the style sheet was enabled when created,
and the user agent hasn’t given up on that particular style sheet yet. A user agent may give up on such a style sheet at any time.
6.4. CSS Rules
A CSS rule is an abstract concept that
denotes a rule as defined by the CSS specification. A
CSS rule is represented as an object that implements a subclass of
the CSSRule
interface, and which has the following
associated state items:
- type
- A non-negative integer associated with a particular type of rule. This item is initialized when a rule is created and cannot change.
- text
- A text representation of the rule suitable for direct use in a style sheet. This item is initialized when a rule is created and can be changed.
- parent CSS rule
- A reference to an enclosing CSS rule or null. If the rule has an enclosing rule when it is created, then this item is initialized to the enclosing rule; otherwise it is null. It can be changed to null.
- parent CSS style sheet
- A reference to a parent CSS style sheet or null. This item is initialized to reference an associated style sheet when the rule is created. It can be changed to null.
- child CSS rules
- A list of child CSS rules. The list can be mutated.
In addition to the above state, each CSS rule may be associated with other state in accordance with its type.
To parse a CSS rule from a string string, run the following steps:
- Let rule be the return value of invoking parse a rule with string.
- If rule is a syntax error, return rule.
- Let parsed rule be the result of parsing rule according to the appropriate CSS specifications, dropping parts that are said to be ignored. If the whole rule is dropped, return a syntax error.
- Return parsed rule.
To serialize a CSS rule, perform one of the following in accordance with the CSS rule’s type:
CSSStyleRule
-
Return the result of the following steps:
- Let s initially be
the result of performing serialize a group of selectors on the rule’s associated selectors,
followed by the string "
{
", i.e., a single SPACE (U+0020), followed by LEFT CURLY BRACKET (U+007B). - Let decls be the result of performing serialize a CSS declaration block on the rule’s associated declarations, or null if there are no such declarations.
- Let rules be the result of performing serialize a CSS rule on each rule in the rule’s
cssRules
list, or null if there are no such rules. - If decls and rules are both null, append " }" to s (i.e. a single SPACE (U+0020) followed by RIGHT CURLY BRACKET (U+007D)) and return s.
-
If rules is null:
- Append a single SPACE (U+0020) to s
- Append decls to s
- Append " }" to s (i.e. a single SPACE (U+0020) followed by RIGHT CURLY BRACKET (U+007D)).
- Return s.
-
Otherwise:
- If decls is not null, prepend it to rules.
-
For each rule in rules:
- If rule is the empty string, do nothing.
-
Otherwise:
- Append a newline followed by two spaces to s.
- Append rule to s.
- Append a newline followed by RIGHT CURLY BRACKET (U+007D) to s.
- Return s.
- Let s initially be
the result of performing serialize a group of selectors on the rule’s associated selectors,
followed by the string "
CSSImportRule
-
The result of concatenating the following:
- The string "
@import
" followed by a single SPACE (U+0020). - The result of performing serialize a URL on the rule’s location.
- If the rule’s associated media list is not empty, a single SPACE (U+0020) followed by the result of performing serialize a media query list on the media list.
- The string "
;
", i.e., SEMICOLON (U+003B).
- The string "
CSSMediaRule
-
The result of concatenating the following:
- The string "
@media
", followed by a single SPACE (U+0020). - The result of performing serialize a media query list on rule’s media query list.
- A single SPACE (U+0020), followed by the string "{", i.e., LEFT CURLY BRACKET (U+007B), followed by a newline.
- The result of performing serialize a CSS rule on each rule in the rule’s
cssRules
list, filtering out empty strings, indenting each item with two spaces, all joined with newline. - A newline, followed by the string "}", i.e., RIGHT CURLY BRACKET (U+007D)
- The string "
CSSFontFaceRule
-
The result of concatenating the following:
- The string "
@font-face {
", followed by a single SPACE (U+0020). - The string "
font-family:
", followed by a single SPACE (U+0020). - The result of performing serialize a string on the rule’s font family name.
- The string "
;
", i.e., SEMICOLON (U+003B). -
If the rule’s associated source list is not empty, follow these substeps:
- A single SPACE (U+0020), followed by the string "
src:
", followed by a single SPACE (U+0020). - The result of invoking serialize a comma-separated list on performing serialize a URL or serialize a LOCAL for each source on the source list.
- The string "
;
", i.e., SEMICOLON (U+003B).
- A single SPACE (U+0020), followed by the string "
- If rule’s associated unicode-range descriptor is present, a single
SPACE (U+0020), followed by the string "
unicode-range:
", followed by a single SPACE (U+0020), followed by the result of performing serialize a <'unicode-range'>, followed by the string ";
", i.e., SEMICOLON (U+003B). - If rule’s associated font-variant descriptor is present, a single
SPACE (U+0020), followed by the string "
font-variant:
", followed by a single SPACE (U+0020), followed by the result of performing serialize a <'font-variant'>, followed by the string ";
", i.e., SEMICOLON (U+003B). - If rule’s associated font-feature-settings descriptor is present, a
single SPACE (U+0020), followed by the string "
font-feature-settings:
", followed by a single SPACE (U+0020), followed by the result of performing serialize a <'font-feature-settings'>, followed by the string ";
", i.e., SEMICOLON (U+003B). - If rule’s associated font-stretch descriptor is present, a single
SPACE (U+0020), followed by the string "
font-stretch:
", followed by a single SPACE (U+0020), followed by the result of performing serialize a <'font-stretch'>, followed by the string ";
", i.e., SEMICOLON (U+003B). - If rule’s associated font-weight descriptor is present, a single SPACE
(U+0020), followed by the string "
font-weight:
", followed by a single SPACE (U+0020), followed by the result of performing serialize a <'font-weight'>, followed by the string ";
", i.e., SEMICOLON (U+003B). - If rule’s associated font-style descriptor is present, a single SPACE
(U+0020), followed by the string "
font-style:
", followed by a single SPACE (U+0020), followed by the result of performing serialize a <'font-style'>, followed by the string ";
", i.e., SEMICOLON (U+003B). - A single SPACE (U+0020), followed by the string "}", i.e., RIGHT CURLY BRACKET (U+007D).
Need to define how the
CSSFontFaceRule
descriptors' values are serialized. - The string "
CSSPageRule
-
Need to define how
CSSPageRule
is serialized. CSSNamespaceRule
- The literal string "
@namespace
", followed by a single SPACE (U+0020), followed by the serialization as an identifier of theprefix
attribute (if any), followed by a single SPACE (U+0020) if there is a prefix, followed by the serialization as URL of thenamespaceURI
attribute, followed the character ";
" (U+003B). CSSKeyframesRule
-
The result of concatenating the following:
- The literal string "
@keyframes
", followed by a single SPACE (U+0020). - The serialization of the
name
attribute. If the attribute is a CSS wide keyword, or the value default, or the value none, then it is serialized as a string. Otherwise, it is serialized as an identifier. - The string "
{
", i.e., a single SPACE (U+0020), followed by LEFT CURLY BRACKET (U+007B), followed by a single SPACE (U+0020). - The result of performing serialize a CSS rule on each rule in the rule’s
cssRules
list, separated by a newline and indented by two spaces. - A newline, followed by the string "}", i.e., RIGHT CURLY BRACKET (U+007D)
- The literal string "
CSSKeyframeRule
-
The result of concatenating the following:
- The
keyText
. - The string "
{
", i.e., a single SPACE (U+0020), followed by LEFT CURLY BRACKET (U+007B), followed by a single SPACE (U+0020). - The result of performing serialize a CSS declaration block on the rule’s associated declarations.
- If the rule is associated with one or more declarations, the string "
- The string "
}
", RIGHT CURLY BRACKET (U+007D).
- The
The "indented by two spaces" bit matches browsers, but needs work, see #5494
To insert a CSS rule rule in a CSS rule list list at index index, with a flag nested, follow these steps:
- Set length to the number of items in list.
- If index is greater than length, then throw
an
IndexSizeError
exception. - Set new rule to the results of performing parse a CSS rule on argument rule.
-
If new rule is a syntax error, and nested is set,
perform the following substeps:
- Set declarations to the results of performing parse a CSS declaration block, on argument rule.
- If declarations is empty, throw a
SyntaxError
exception. - Otherwise, set new rule to a new nested declarations rule with declarations as it contents.
- If new rule is a syntax error, throw
a
SyntaxError
exception. -
If new rule cannot be inserted into list at the zero-indexed position index due to constraints
specified by CSS, then throw
a
HierarchyRequestError
exception. [CSS21]Note: For example, a CSS style sheet cannot contain an
@import
at-rule after a style rule. - If new rule is an
@namespace
at-rule, and list contains anything other than@import
at-rules, and@namespace
at-rules, throw anInvalidStateError
exception. - Insert new rule into list at the zero-indexed position index.
- Return index.
To remove a CSS rule from a CSS rule list list at index index, follow these steps:
- Set length to the number of items in list.
- If index is greater than or equal to length, then throw
an
IndexSizeError
exception. - Set old rule to the indexth item in list.
- If old rule is an
@namespace
at-rule, and list contains anything other than@import
at-rules, and@namespace
at-rules, throw anInvalidStateError
exception. - Remove rule old rule from list at the zero-indexed position index.
- Set old rule’s parent CSS rule and parent CSS style sheet to null.
6.4.1. The CSSRuleList
Interface
The CSSRuleList
interface represents an ordered collection of CSS rules.
[Exposed =Window ]interface {
CSSRuleList getter CSSRule ?item (unsigned long );
index readonly attribute unsigned long length ; };
The object’s supported property indices are the numbers in the range zero to one less than the number of
CSSRule
objects represented by the collection. If there are no such CSSRule
objects, then there are no
supported property indices.
The item(index)
method must return the indexth CSSRule
object in the collection. If there is no indexth object in the collection, then the method must return null.
The length
attribute must return the number of CSSRule
objects represented by the
collection.
6.4.2. The CSSRule
Interface
The CSSRule
interface represents an abstract, base CSS rule. Each
distinct CSS rule type is represented by a distinct interface that
inherits from this interface.
[Exposed =Window ]interface {
CSSRule attribute CSSOMString cssText ;readonly attribute CSSRule ?parentRule ;readonly attribute CSSStyleSheet ?parentStyleSheet ; // the following attribute and constants are historicalreadonly attribute unsigned short type ;const unsigned short = 1;
STYLE_RULE const unsigned short = 2;
CHARSET_RULE const unsigned short = 3;
IMPORT_RULE const unsigned short = 4;
MEDIA_RULE const unsigned short = 5;
FONT_FACE_RULE const unsigned short = 6;
PAGE_RULE const unsigned short = 9;
MARGIN_RULE const unsigned short = 10; };
NAMESPACE_RULE
The cssText
attribute must return a serialization of the
CSS rule.
On setting the cssText
attribute must do nothing.
The parentRule
attribute must return the parent CSS
rule.
Note: For example, @media
can enclose a rule, in which case parentRule
would
be non-null; in cases where there is no enclosing rule, parentRule
will be null.
The parentStyleSheet
attribute must return the
parent CSS style sheet.
Note: The only circumstance where null is returned when a rule has been removed.
Note: Removing a Node
that implements the LinkStyle
interface from a
Document
instance does not (by itself) cause the CSSStyleSheet
referenced by a CSSRule
to be
unreachable.
The type
attribute is deprecated.
It must return an integer, as follows:
- If the object is a
CSSStyleRule
- Return 1.
- If the object is a
CSSImportRule
- Return 3.
- If the object is a
CSSMediaRule
- Return 4.
- If the object is a
CSSFontFaceRule
- Return 5.
- If the object is a
CSSPageRule
- Return 6.
- If the object is a
CSSKeyframesRule
- Return 7.
- If the object is a
CSSKeyframeRule
- Return 8.
- If the object is a
CSSMarginRule
- Return 9.
- If the object is a
CSSNamespaceRule
- Return 10.
- If the object is a
CSSCounterStyleRule
- Return 11.
- If the object is a
CSSSupportsRule
- Return 12.
- If the object is a
CSSFontFeatureValuesRule
- Return 14.
- Otherwise
- Return 0.
Note: The practice of using an integer enumeration
and several constants to identify the integers
is a legacy design practice that is no longer used in Web APIs.
Instead, to tell what type of rule a given object is,
it is recommended to check rule
,
which will return a string like
.
This enumeration is thus frozen in its current state,
and no new new values will be added to reflect additional at-rules;
all at-rules beyond the ones listed above will return 0.
6.4.3. The CSSStyleRule
Interface
The CSSStyleRule
interface represents a style rule.
[Exposed =Window ]interface :
CSSStyleRule CSSGroupingRule {attribute CSSOMString selectorText ; [SameObject ,PutForwards =cssText ]readonly attribute CSSStyleProperties style ; };
The selectorText
attribute, on getting, must return the result of
serializing the rule’s associated selector list.
On setting the selectorText
attribute these steps must be run:
- Run the parse a group of selectors algorithm on the given value.
- If the algorithm returns a non-null value replace the associated selector list with the returned value.
- Otherwise, if the algorithm returns a null value, do nothing.
The style
attribute must return a CSSStyleProperties
object for the style rule, with the
following properties:
- computed flag
- Unset.
- readonly flag
- Unset.
- declarations
- The declared declarations in the rule, in specified order.
- parent CSS rule
- this.
- owner node
- Null.
The specified order for declarations is the same as specified, but with shorthand properties expanded into their longhand properties, in canonical order. If a property is specified more than once (after shorthand expansion), only the one with greatest cascading order must be represented, at the same relative position as it was specified. [CSS3CASCADE]
6.4.4. The CSSImportRule
Interface
The CSSImportRule
interface represents an @import
at-rule.
[Exposed =Window ]interface :
CSSImportRule CSSRule {readonly attribute USVString href ; [SameObject ,PutForwards =mediaText ]readonly attribute MediaList media ; [SameObject ]readonly attribute CSSStyleSheet ?styleSheet ;readonly attribute CSSOMString ?layerName ;readonly attribute CSSOMString ?supportsText ; };
The href
attribute must return the URL specified by
the @import
at-rule.
Note: To get the resolved URL use the href
attribute of the associated CSS style sheet.
The media
attribute must return the value of the