sass-site/source/documentation/at-rules/css.html.md.erb

169 lines
4.1 KiB
Plaintext
Raw Normal View History

2018-09-01 22:35:20 +02:00
---
title: CSS At-Rules
table_of_contents: true
2018-09-01 22:35:20 +02:00
---
<% impl_status dart: '1.15.0', libsass: false, ruby: false do %>
LibSass, Ruby Sass, and older versions of Dart Sass don't support
[interpolation][] in at-rule names. They do support interpolation in values.
[interpolation]: ../interpolation
<% end %>
2018-09-01 22:35:20 +02:00
Sass supports all the at-rules that are part of CSS proper. To stay flexible and
forwards-compatible with future versions of CSS, Sass has general support that
covers almost all at-rules by default. A CSS at-rule is written
`@<name> <value>`, `@<name> { ... }`, or `@<name> <value> { ... }`. The name
must be an identifier, and the value (if one exists) can be pretty much
anything. Both the name and the value can contain [interpolation][].
2018-09-01 22:35:20 +02:00
[interpolation]: ../interpolation
<% example do %>
@namespace svg url(http://www.w3.org/2000/svg);
@font-face {
font-family: "Open Sans";
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}
@counter-style thumbs {
system: cyclic;
symbols: "\1F44D";
}
===
@namespace svg url(http://www.w3.org/2000/svg)
@font-face
font-family: "Open Sans"
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2")
@counter-style thumbs
system: cyclic
symbols: "\1F44D"
2018-09-01 22:35:20 +02:00
<% end %>
If a CSS at-rule is nested within a style rule, the two automatically swap
positions so that the at-rule is at the top level of the CSS output and the
style rule is within it. This makes it easy to add conditional styling without
having to rewrite the style rule's selector.
<% example do %>
.print-only {
display: none;
2018-09-01 22:35:20 +02:00
@media print { display: block; }
}
===
.print-only
display: none
2018-09-01 22:35:20 +02:00
@media print
display: block
2018-09-01 22:35:20 +02:00
<% end %>
## `@media`
<% impl_status dart: '1.11.0', libsass: false, ruby: '3.7.0' do %>
LibSass and older versions of Dart Sass and Ruby Sass don't support media
queries with features written in a [range context][]. They do support other
standard media queries.
[range context]: https://www.w3.org/TR/mediaqueries-4/#mq-range-context
<% example(autogen_css: false) do %>
@media (width <= 700px) {
body {
background: green;
}
}
===
@media (width <= 700px)
body
background: green
===
@media (width <= 700px) {
body {
background: green;
}
}
<% end %>
<% end %>
2018-09-01 22:35:20 +02:00
The [`@media` rule][] does all of the above and more. In addition to allowing
interpolation, it allows [SassScript expressions][] to be used directly in the
[feature queries][].
[`@media` rule]: https://developer.mozilla.org/en-US/docs/Web/CSS/Media_Queries/Using_media_queries
[SassScript expressions]: ../syntax/structure#expressions
[feature queries]: https://developer.mozilla.org/en-US/docs/Web/CSS/Media_Queries/Using_media_queries#Targeting_media_features
<% example do %>
$layout-breakpoint-small: 960px;
2018-09-01 22:35:20 +02:00
@media (min-width: $layout-breakpoint-small) {
.hide-extra-small {
display: none;
}
2018-09-01 22:35:20 +02:00
}
===
$layout-breakpoint-small: 960px
2018-09-01 22:35:20 +02:00
@media (min-width: $layout-breakpoint-small)
.hide-extra-small
display: none
2018-09-01 22:35:20 +02:00
<% end %>
When possible, Sass will also merge media queries that are nested within one
another to make it easier to support browsers that don't yet natively support
nested `@media` rules.
<% example do %>
@media (hover: hover) {
.button:hover {
border: 2px solid black;
2018-09-01 22:35:20 +02:00
@media (color) {
border-color: #036;
}
2018-09-01 22:35:20 +02:00
}
}
===
@media (hover: hover)
.button:hover
border: 2px solid black
@media (color)
border-color: #036
2018-09-01 22:35:20 +02:00
<% end %>
## `@supports`
The [`@supports` rule][] also allows [SassScript expressions][] to be used in
the declaration queries.
[`@supports` rule]: https://developer.mozilla.org/en-US/docs/Web/CSS/@supports
<% example do %>
@mixin sticky-position {
position: fixed;
@supports (position: sticky) {
position: sticky;
}
2018-09-01 22:35:20 +02:00
}
.banner {
@include sticky-position;
}
===
@mixin sticky-position
position: fixed
@supports (position: sticky)
position: sticky
2018-09-01 22:35:20 +02:00
.banner
@include sticky-position
2018-09-01 22:35:20 +02:00
<% end %>