Oblast viditelnosti proměnných a bloků obsahu v SASS
Při předávání bloků obsahu do mixinu je jejich oblast viditelnosti určena konkrétním umístěním bloku, nikoli mixinu. Proto nemůžeme používat lokální proměnné mixinu v předávaném bloku obsahu, který bude schopen pracovat pouze s globálními proměnnými.
Podívejme se na následující příklad:
$size: 14px;
@mixin sizes ($size: 20px) {
font-size: $size;
padding: $size;
@content;
}
.navbar {
@include sizes {
margin: $size;
}
}
Výsledek kompilace:
.navbar {
font-size: 20px;
padding: 20px;
margin: 14px;
}
Řekněte, jaký bude výsledek kompilace následujícího kódu:
$color: yellow;
@mixin links ($color: red) {
background: $color;
@content;
}
Řekněte, jaký bude výsledek kompilace následujícího kódu:
$color: yellow;
$size: 10px;
@mixin links ($color: red, $size: 12px) {
background-color: $color;
font-size: $size;
@content;
}
.navbar {
@include links {
box-shadow: $color;
padding: $size;
}
}
Řekněte, jaký bude výsledek kompilace následujícího kódu:
$color: green;
$size: 6px;
@mixin links ($color: red, $size: 10px) {
color: $color;
font-size: $size;
@content;
}
.navbar {
@include links {
border-color: $color;
margin: $size;
}
}
#active{
@include links{
background-color: $color;
padding-top: $size;
padding-bottom: $size * 2;
}
}