У меня есть два вызова карт 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);
}
}
}
map-1-color-1
. Если есть, то вы хотите создать класс.my-class
сcolor
шестнадцатеричным числомmap-1-color-1
. Правильно ли я понял? - person ReSedano   schedule 22.12.2018@each
условие.@each $key , $value in $my-map-1{ @if ($key == map-1-color-1){ .my-class{ @include color-mix($color:$value); } } }
Но мне нужно сделать это с помощью функции. - person Navidu Kunu   schedule 22.12.2018