Omfång för variabler och innehållsblock i SASS
När innehållsblock skickas till en mixin bestäms deras omfång av blockets specifika placering, inte mixinen. Därför kan vi inte använda mixinens lokala variabler i det överförda innehållsblocket, som endast kommer att kunna arbeta med globala variabler.
Låt oss överväga följande exempel:
$size: 14px;
@mixin sizes ($size: 20px) {
font-size: $size;
padding: $size;
@content;
}
.navbar {
@include sizes {
margin: $size;
}
}
Resultat av kompilering:
.navbar {
font-size: 20px;
padding: 20px;
margin: 14px;
}
Berätta vad som blir resultatet av kompileringen av följande kod:
$color: yellow;
@mixin links ($color: red) {
background: $color;
@content;
}
Berätta vad som blir resultatet av kompileringen av följande kod:
$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;
}
}
Berätta vad som blir resultatet av kompileringen av följande kod:
$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;
}
}