Как отделить возвращаемые значения функции scss
У меня две карты SCSS $my-map-1
а также $my-map-2
, Каждая карта имеет ключи с шестнадцатеричным значением. Я написал функцию для возврата ключа и шестнадцатеричных значений ($key
, $value
) каждой карты отдельно.
После этого я написал @if
условие с моей функцией, чтобы проверить карту. Я передаю имя моей карты в функцию. Если карта там, проверьте это $key
равный данному имени. Если это правда, передайте $valu
того, что $key
на мой цвет миксин. Это мой код
$my-map-1: (
map-1-color-1: #506c89,
map-1-color-2: #737373,
map-1-color-3: #2a3949,
map-1-color-4: #182028,
);
$my-map-2: (
map-2-color-1: #fff,
map-2-color-2: #000,
map-2-color-3: #ddd,
map-2-color-4: #ccc,
);
//the function to read te map and return the key and the value.
@function color-map($color-map) {
@each $key, $value in $color-map {
@return ($key, $value);
}
}
//mixin
@mixin color-mix($color){
color: $color;
}
//css classes from here
@if color-map($my-map-1) {
if($key == map-1-color-1) {
.my-class{
@include color-mix($color:$value);
}
}
}
1 ответ
Решение
Ты можешь использовать map-get
Метод, это очень полезно: http://sass-lang.com/documentation/Sass/Script/Functions.html
Это пример миксина. Я передаю в качестве аргумента и ваш ключ: может быть, лучше, потому что вы можете проверить и другие имена ключей, если вам это нужно:
$my-map-1: (
map-1-color-1: #506c89,
map-1-color-2: #737373,
map-1-color-3: #2a3949,
map-1-color-4: #182028
);
$my-map-2: (
map-2-color-1: #fff,
map-2-color-2: #000,
map-2-color-3: #ddd,
map-2-color-4: #ccc
);
@mixin color-map($color-map, $key-map) {
@each $key, $value in $color-map {
@if($key == $key-map) {
.my-class{
color: map-get($color-map, $key);
}
}
}
}
@include color-map($my-map-1, map-1-color-1);
Ваш вывод будет:
.my-class {
color: #506c89;
}