我有一个用于盒子阴影的sass mixin,它看起来像这样:
@mixin box-shadow($hLength, $vLength, $blur, $spread, $colour, $type:""){
@if $type != "" {
-webkit-box-shadow:$type $hLength $vLength $blur $spread $colour;
-moz-box-shadow:$type $hLength $vLength $blur $spread $colour;
box-shadow:$type $hLength $vLength $blur $spread $colour;
}
}
这对我的大多数应用都很好 .
但是我现在需要以某种方式修改我的方法 .
我有列表项,可以有11个类之一,这个类控制列表项的颜色和图标 .
我变量的例子:
$channel1: #19BC9C;
$channel2: #F1C40E;
$channel3: #9B59B6;
$channel4: #3398DB;
我列表项目的sass如下所示:
li {
&.channel1 {
@include box-shadow(-3px, 0px, 0px, 0px, $channel1, inset);
}
&.channel2 {
@include box-shadow(-3px, 0px, 0px, 0px, $channel2, inset);
}
}
问题是每个类元素的px值和插入是相同的 . 但是没有box-shadow-color的属性,所以我无法拆分参数 .
我希望我能在一个单独的变量中存储-3px,0px,0px,0px并将其传入 .
@include box-shadow($channelBorder, $channel1, inset);
等,但这不起作用 .
有谁知道是否有一个像样的解决方案,我宁愿尽可能保持我的mixin .
1 回答
通常可以通过在mixin上使用默认值并仅指定要修改的确切值来解决此问题:
或者,您可以将参数的一部分存储为列表,并在调用mixin时展开它们:
但是,你永远不会对这样的mixin感到满意,因为它只假设你会有一个盒子阴影,但属性允许倍数 .
从长远来看,如果你可以遍历你想要的值并调用更强大的mixin,那么对你来说简单得多: