While Shadow DOM offers web developers the affordance of a style isolation boundary, it is not always the case that a component desires pure isolation. In many cases, component authors (or more generally any web development team working together on a single composed web application) may want to associate a default style with a component without worrying that the specificity and/or ordering of the selectors might cause a conflict with other author styles intended to affect the same component.
At Microsoft, our WinJS framework team ran into the above problem a lot: styles intended to be a baseline/ default style would inadvertently take precedence over other author styles due to how CSS calculates specificity within an author style sheet.
To address these problems, authors should be able to indicate that a group of selectors shall be designated as "default" styles, to be processed at an earlier level in the cascade (i.e., applied before other author styles). Default styles allow authors to specify a set of styles that behave as if they were built-in or provided by the user agent itself.
As with all proposals this is one possible implementation of the concept:
The @default rule
<body>
<pre id="color">Text Color</pre>
</body>
@default {
pre#color { color: red; }
}
pre { color: green; }
The Text Color
is green. The author style (a less-specific selector) overrides the default style (a more specific selector) because it is evaluated earlier in the CSS cascade. Remove the author style (or set its color to ‘default’ to get back to the red default.
The origin of a declaration is based on where it comes from and its importance is whether or not it is declared !important (see below). The precedence of the various origins is, in descending order:
- Transition declarations
- Important user agent declarations
- Important default declarations
<-- Added
- Important user declarations
- Important override declarations
- Important author declarations
- Animation declarations
- Normal override declarations
- Normal author declarations
- Normal user declarations
- Normal default declarations
<-- Added
- Normal user agent declarations
Declarations from origins earlier in this list win over declarations from later origins.
Each property has a default value, defined by the default style sheet. If no default style sheet is defined then the values are the same as the user agent style sheet.
- Why use another at-rule? Should the mechanism be done outside of CSS (e.g., a new
link[rel]
method)?
- I think it may be useful for default styles to be nestable within other at-rules (and vice-versa), such as @document, @media, etc., which isn’t possible if defined out of CSS itself.
- !unimportant was my initial idea that sprang to mind, but it might become tedious to add that annotation to a large set of styles...
- What does !important do in a default style declaration?
- Like in author style sheets, the !important rules promotes those declarations into another layer. This has the someone odd effect of making the default !important rules more important than a normal !important declaration! This is just how it fell out in the cascade order by natural reflection of the cascade. We could probably change this if necessary.