150 lines
3.7 KiB
Plaintext
Raw Normal View History

---
title: "@if and @else"
table_of_contents: true
introduction: >
The `@if` rule is written `@if <expression> { ... }`, and it controls whether
or not its block gets evaluated (including emitting any styles as CSS). The
2023-05-30 16:27:01 -04:00
[expression](/documentation/syntax/structure#expressions) usually returns
either [`true` or `false`](/documentation/values/booleans)—if the expression
returns `true`, the block is evaluated, and if the expression returns `false`
its not.
---
{% render 'code-snippets/example-if' %}
{% markdown %}
2023-05-30 17:23:34 -04:00
## `@else`
2023-05-30 17:23:34 -04:00
An `@if` rule can optionally be followed by an `@else` rule, written `@else {
... }`. This rule's block is evaluated if the `@if` expression returns
`false`.
{% endmarkdown %}
{% codeExample 'if' %}
2023-05-30 17:23:34 -04:00
$light-background: #f2ece4;
$light-text: #036;
$dark-background: #6b717f;
$dark-text: #d2e1dd;
@mixin theme-colors($light-theme: true) {
@if $light-theme {
background-color: $light-background;
color: $light-text;
} @else {
background-color: $dark-background;
color: $dark-text;
}
}
2023-05-30 17:23:34 -04:00
.banner {
@include theme-colors($light-theme: true);
body.dark & {
@include theme-colors($light-theme: false);
}
}
2023-05-30 17:23:34 -04:00
===
$light-background: #f2ece4
$light-text: #036
$dark-background: #6b717f
$dark-text: #d2e1dd
@mixin theme-colors($light-theme: true)
@if $light-theme
background-color: $light-background
color: $light-text
@else
background-color: $dark-background
color: $dark-text
.banner
@include theme-colors($light-theme: true)
body.dark &
@include theme-colors($light-theme: false)
{% endcodeExample %}
{% markdown %}
2023-05-30 17:23:34 -04:00
Conditional expressions may contain [boolean operators][] (`and`, `or`, `not`).
2023-05-30 17:23:34 -04:00
[boolean operators]: /documentation/operators/boolean
2023-05-30 17:23:34 -04:00
### `@else if`
2023-05-30 17:23:34 -04:00
You can also choose whether to evaluate an `@else` rule's block by writing it
`@else if <expression> { ... }`. If you do, the block is evaluated only if the
preceding `@if`'s expression returns `false` *and* the `@else if`'s expression
returns `true`.
2023-05-30 17:23:34 -04:00
In fact, you can chain as many `@else if`s as you want after an `@if`. The
first block in the chain whose expression returns `true` will be evaluated, and
no others. If there's a plain `@else` at the end of the chain, its block will be
evaluated if every other block fails.
{% endmarkdown %}
{% codeExample 'else' %}
2023-05-30 17:23:34 -04:00
@use "sass:math";
@mixin triangle($size, $color, $direction) {
height: 0;
width: 0;
border-color: transparent;
border-style: solid;
border-width: math.div($size, 2);
@if $direction == up {
border-bottom-color: $color;
} @else if $direction == right {
border-left-color: $color;
} @else if $direction == down {
border-top-color: $color;
} @else if $direction == left {
border-right-color: $color;
} @else {
@error "Unknown direction #{$direction}.";
}
}
.next {
@include triangle(5px, black, right);
}
===
@use "sass:math"
@mixin triangle($size, $color, $direction)
height: 0
width: 0
border-color: transparent
border-style: solid
border-width: math.div($size, 2)
@if $direction == up
border-bottom-color: $color
@else if $direction == right
border-left-color: $color
@else if $direction == down
border-top-color: $color
@else if $direction == left
border-right-color: $color
@else
@error "Unknown direction #{$direction}."
.next
@include triangle(5px, black, right)
===
.next {
height: 0;
width: 0;
border-color: transparent;
border-style: solid;
border-width: 2.5px;
border-left-color: black;
}
{% endcodeExample %}
2023-05-30 16:27:01 -04:00
{% render 'documentation/snippets/truthiness-and-falsiness' %}