2023-05-30 12:10:07 +02:00
|
|
|
|
---
|
|
|
|
|
title: "@each"
|
|
|
|
|
introduction: >
|
|
|
|
|
The `@each` rule makes it easy to emit styles or evaluate code for each
|
|
|
|
|
element of a [list](/documentation/values/lists) or each pair in a
|
2023-05-30 22:27:01 +02:00
|
|
|
|
[map](/documentation/values/maps). It’s great for repetitive styles that only
|
|
|
|
|
have a few variations between them. It’s usually written `@each <variable> in
|
2023-05-30 12:10:07 +02:00
|
|
|
|
<expression> { ... }`, where the
|
2023-05-30 22:27:01 +02:00
|
|
|
|
[expression](/documentation/syntax/structure#expressions) returns a list. The
|
|
|
|
|
block is evaluated for each element of the list in turn, which is assigned to
|
|
|
|
|
the given variable name.
|
2023-05-30 12:10:07 +02:00
|
|
|
|
---
|
|
|
|
|
|
2023-06-03 00:18:43 +02:00
|
|
|
|
{% render 'code_snippets/example-each-list' %}
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-06-21 21:20:03 +02:00
|
|
|
|
## With Maps
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-06-21 21:20:03 +02:00
|
|
|
|
You can also use `@each` to iterate over every key/value pair in a map by
|
|
|
|
|
writing it `@each <variable>, <variable> in <expression> { ... }`. The key is
|
|
|
|
|
assigned to the first variable name, and the element is assigned to the second.
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-06-03 00:18:43 +02:00
|
|
|
|
{% render 'code_snippets/example-each-map' %}
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-06-21 21:20:03 +02:00
|
|
|
|
## Destructuring
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-06-21 21:20:03 +02:00
|
|
|
|
If you have a list of lists, you can use `@each` to automatically assign
|
|
|
|
|
variables to each of the values from the inner lists by writing it `@each
|
|
|
|
|
<variable...> in <expression> { ... }`. This is known as *destructuring*, since
|
|
|
|
|
the variables match the structure of the inner lists. Each variable name is
|
|
|
|
|
assigned to the value at the corresponding position in the list, or [`null`][]
|
|
|
|
|
if the list doesn't have enough values.
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-06-21 21:20:03 +02:00
|
|
|
|
[`null`]: /documentation/values/null
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
|
|
|
|
{% codeExample 'each' %}
|
2023-05-30 23:23:34 +02:00
|
|
|
|
$icons:
|
|
|
|
|
"eye" "\f112" 12px,
|
|
|
|
|
"start" "\f12e" 16px,
|
|
|
|
|
"stop" "\f12f" 10px;
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-05-30 23:23:34 +02:00
|
|
|
|
@each $name, $glyph, $size in $icons {
|
|
|
|
|
.icon-#{$name}:before {
|
|
|
|
|
display: inline-block;
|
|
|
|
|
font-family: "Icon Font";
|
|
|
|
|
content: $glyph;
|
|
|
|
|
font-size: $size;
|
|
|
|
|
}
|
2023-05-30 12:10:07 +02:00
|
|
|
|
}
|
2023-05-30 23:23:34 +02:00
|
|
|
|
===
|
|
|
|
|
$icons: "eye" "\f112" 12px, "start" "\f12e" 16px, "stop" "\f12f" 10px
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-05-30 22:27:01 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-30 23:23:34 +02:00
|
|
|
|
@each $name, $glyph, $size in $icons
|
|
|
|
|
.icon-#{$name}:before
|
|
|
|
|
display: inline-block
|
|
|
|
|
font-family: "Icon Font"
|
|
|
|
|
content: $glyph
|
|
|
|
|
font-size: $size
|
2023-05-30 12:10:07 +02:00
|
|
|
|
{% endcodeExample %}
|
|
|
|
|
|
|
|
|
|
{% funFact %}
|
2023-05-30 23:23:34 +02:00
|
|
|
|
Because `@each` supports destructuring and [maps count as lists of lists][],
|
|
|
|
|
`@each`'s map support works without needing special support for maps in
|
|
|
|
|
particular.
|
2023-05-30 12:10:07 +02:00
|
|
|
|
|
2023-05-30 23:23:34 +02:00
|
|
|
|
[maps count as lists of lists]: /documentation/values/maps
|
2023-05-30 12:10:07 +02:00
|
|
|
|
{% endfunFact %}
|