@when
/@else
conditional rules
data:image/s3,"s3://crabby-images/c7d6d/c7d6dffc19ee1233013b07057be67e814a7862a6" alt=""
No
data:image/s3,"s3://crabby-images/e4103/e4103e0141fe50d1f35107a919be0411c0d2eb0c" alt=""
No
data:image/s3,"s3://crabby-images/e6a79/e6a79a00d827c24d743dc488b1447197dfed126f" alt=""
No
data:image/s3,"s3://crabby-images/8222e/8222e560f62b145418aca69afb5ca0522d087996" alt=""
No
If you worked with conditional rules like @media
and @supports
you might have found it cumbersome to make them work together. @when
and @else
can group conditions together and make them work as a single rule.
@when media(width >= 400px) and media(pointer: fine) and supports(display: flex) {
/* A */
} @else supports(caret-color: pink) and supports(background: double-rainbow()) {
/* B */
} @else {
/* C */
}
Here’s how you would do it without @when
:
Old version
@media (width >= 400px) and (pointer: fine) {
@supports (display: flex) {
/* A */
}
@supports not (display: flex) {
@supports (caret-color: pink) and (background: double-rainbow()) {
/* B */
}
@supports not ((caret-color: pink) and (background: double-rainbow())) {
/* C */
}
}
}
@media not ((width >= 400px) and (pointer: fine)) {
@supports (caret-color: pink) and (background: double-rainbow()) {
/* B */
}
@supports not ((caret-color: pink) and (background: double-rainbow())) {
/* C */
}
}