Arbeiten auf einem Cross-Browser-Gradienten @Mixin Ich habe meinen Schwanz seit über zwei Stunden verfolgt.SASS Farbverlauf @Mixin macht mich verrückt
Ich versuche, dieses Ergebnis zu erhalten:
-moz-linear-gradient(left, #fff 0%, #000 100%);
Aus den Standardargumente geliefert in:
@mixin gradient($type:linear, $gradient:(#fff 0%, #000 100%), $shape:vertical, $repeat:false){
background:nth(nth($gradient, 1), 1);
$background:null;
$vendors:null;
@if $shape == vertical {
$vendors: (
mozilla: (-moz-, top),
webkit: (-webkit-, top),
opera: (-o-, top),
standard: ("", to bottom)
);
}@else if $shape == horizontal {
$vendors: (
mozilla: (-moz-, left),
webkit: (-webkit-, right),
opera: (-o-, right),
standard: ("", to right)
);
}@else{
$vendors: (
mozilla: (-moz-, $shape),
webkit: (-webkit-, $shape),
opera: (-o-, $shape),
standard: ("", to $shape)
);
}
@if $repeat == true{
$background:repeating-+$type+-gradient;
}@else if $repeat == false {
$background:$type+-gradient;
}
@if $type == linear {
@each $vendor in $vendors {
background:[?????];
}
}@elseif $type == radial {
@each $vendor in $vendors {
background:[?????];
}
}
}
Ich würde wirklich auf diesen einen helfen schätzen, bevor ich meinen Laptop zertrümmern mit meinem Kopf!
Persönlich würde ich schreiben Sie einfach den mixin Dann führe autoprefixer aus und kümmere dich um die Präfixe. Tun Sie einfach so etwas "= Farben ($ color1, $ color2, $ color3) \t Hintergrund: linear-gradient ($ color1, $ color2, $ color3)" und fügen Sie den Rest der Anforderungen als Variablen hinzu. Dann schließe die Variablen an, wenn du das Mixin verwendest – Brad