80 lines
2.7 KiB
Plaintext
Raw Normal View History

---
title: "@at-root"
introduction: >
The `@at-root` rule is usually written `@at-root <selector> { ... }` and
causes everything within it to be emitted at the root of the document instead
of using the normal nesting. It's most often used when doing [advanced
2023-05-30 16:27:01 -04:00
nesting](/documentation/style-rules/parent-selector#advanced-nesting) with the
[SassScript parent
selector](/documentation/style-rules/parent-selector#in-sassscript) and
[selector functions](/documentation/modules/selector).
---
2023-06-02 18:18:43 -04:00
{% render 'code_snippets/example-advanced-nesting' %}
{% markdown %}
2023-05-30 17:23:34 -04:00
The `@at-root` rule is necessary here because Sass doesn't know what
interpolation was used to generate a selector when it's performing selector
nesting. This means it will automatically add the outer selector to the inner
selector *even if* you used `&` as a SassScript expression. The `@at-root`
explicitly tells Sass not to include the outer selector.
2023-05-30 17:23:34 -04:00
{% funFact %}
The `@at-root` rule can also be written `@at-root { ... }` to put multiple
style rules at the root of the document. In fact, `@at-root <selector> { ...
}` is just a shorthand for `@at-root { <selector> { ... } }`!
{% endfunFact %}
2023-05-30 17:23:34 -04:00
## Beyond Style Rules
2023-05-30 17:23:34 -04:00
On its own, `@at-root` only gets rid of [style rules][]. Any at-rules like
[`@media`][] or [`@supports`][] will be left in. If this isn't what you want,
though, you can control exactly what it includes or excludes using syntax like
[media query features][], written `@at-root (with: <rules...>) { ... }` or
`@at-root (without: <rules...>) { ... }`. The `(without: ...)` query tells
Sass which rules should be excluded; the `(with: ...)` query excludes all
rules *except* those that are listed.
2023-05-30 17:23:34 -04:00
[style rules]: /documentation/style-rules
[`@media`]: /documentation/at-rules/css#media
[`@supports`]: /documentation/at-rules/css#supports
[media query features]: https://developer.mozilla.org/en-US/docs/Web/CSS/Media_Queries/Using_media_queries#Targeting_media_features
{% endmarkdown %}
{% codeExample 'at-root' %}
2023-05-30 17:23:34 -04:00
@media print {
.page {
width: 8in;
2023-05-30 17:23:34 -04:00
@at-root (without: media) {
color: #111;
}
2023-05-30 17:23:34 -04:00
@at-root (with: rule) {
font-size: 1.2em;
}
}
}
2023-05-30 17:23:34 -04:00
===
@media print
.page
width: 8in
2023-05-30 17:23:34 -04:00
@at-root (without: media)
color: #111
2023-05-30 17:23:34 -04:00
@at-root (with: rule)
font-size: 1.2em
{% endcodeExample %}
{% markdown %}
2023-05-30 17:23:34 -04:00
In addition to the names of at-rules, there are two special values that can be
used in queries:
2023-05-30 17:23:34 -04:00
* `rule` refers to style rules. For example, `@at-root (with: rule)` excludes
all at-rules but preserves style rules.
2023-05-30 17:23:34 -04:00
* `all` refers to all at-rules *and* style rules should be excluded.
2023-05-30 16:27:01 -04:00
{% endmarkdown %}