使用可选参数进行Sass mixin

ass CSS

樱AItachi

2020-03-17

我正在写一个像这样的mixin:

@mixin box-shadow($top, $left, $blur, $color, $inset:"") {
    -webkit-box-shadow: $top $left $blur $color $inset;
    -moz-box-shadow: $top $left $blur $color $inset;
    box-shadow: $top $left $blur $color $inset;
}

当真正被调用时,我真正想要的是如果不$inset传递任何,则不会输出任何内容,而是将其编译为如下所示:

-webkit-box-shadow: 2px 2px 5px #555555 "";
-moz-box-shadow: 2px 2px 5px #555555 "";
box-shadow: 2px 2px 5px #555555 "";

如何重写mixin,以便在没有$inset传递值的情况下什么也不输出?

第1933篇《使用可选参数进行Sass mixin》来自Winter(https://github.com/aiyld/aiyld.github.io)的站点

13个回答
HarryGreen前端 2020.03.17

超级简单的方法

只需将默认值添加none到$ inset-这样

@mixin box-shadow($top, $left, $blur, $color, $inset: none) { ....

现在,当没有传递$ inset时,将不会显示任何内容。

AEva 2020.03.17

You can always assign null to your optional arguments. Here is a simple fix

@mixin box-shadow($top, $left, $blur, $color, $inset:null) { //assigning null to inset value makes it optional
    -webkit-box-shadow: $top $left $blur $color $inset;
    -moz-box-shadow: $top $left $blur $color $inset;
    box-shadow: $top $left $blur $color $inset;
}
小胖泡芙 2020.03.17
@mixin box-shadow($left: 0, $top: 0, $blur: 6px, $color: hsla(0,0%,0%,0.25), $inset: false) {
    @if $inset {
        -webkit-box-shadow: inset $left $top $blur $color;
        -moz-box-shadow: inset $left $top $blur $color;
        box-shadow: inset $left $top $blur $color;
    } @else {
        -webkit-box-shadow: $left $top $blur $color;
        -moz-box-shadow: $left $top $blur $color;
        box-shadow: $left $top $blur $color;
    }
}
斯丁乐 2020.03.17

我是CSS编译器的新手,希望能对您有所帮助,

        @mixin positionStyle($params...){

            $temp:nth($params,1);
            @if $temp != null{
            position:$temp;
            }

             $temp:nth($params,2);
            @if $temp != null{
            top:$temp;
            }

             $temp:nth($params,3);
            @if $temp != null{
            right:$temp;
            }

             $temp:nth($params,4);
            @if $temp != null{
            bottom:$temp;
            }

            $temp:nth($params,5);
            @if $temp != null{
            left:$temp;
            }

    .someClass{
    @include positionStyle(absolute,30px,5px,null,null);
    }

//output

.someClass{
position:absolute;
 top: 30px;
 right: 5px;
}
小宇宙理查德 2020.03.17

甚至DRYer方式!

@mixin box-shadow($args...) {
  @each $pre in -webkit-, -moz-, -ms-, -o- {
    #{$pre + box-shadow}: $args;
  } 
  #{box-shadow}: #{$args};
}

现在,您可以更聪明地重用盒子阴影了:

.myShadow {
  @include box-shadow(2px 2px 5px #555, inset 0 0 0);
}
Gil小哥番长 2020.03.17

使用sass@3.4.9:

// declare
@mixin button( $bgcolor:blue ){
    background:$bgcolor;
}

且无价值使用时,按钮将变为蓝色

//use
.my_button{
    @include button();
}

带有值的按钮将为红色

//use
.my_button{
    @include button( red );
}

也与六合一

前端L小小 2020.03.17

我知道这个老问题,但是我认为这仍然有意义。可以说,更清晰的方法是使用unquote()函数(SASS自3.0.0版起使用):

@mixin box-shadow($top, $left, $blur, $color, $inset:"") {
  -webkit-box-shadow: $top $left $blur $color unquote($inset);
  -moz-box-shadow: $top $left $blur $color unquote($inset);
  box-shadow: $top $left $blur $color unquote($inset);
}

这大致相当于Josh的答案,但是我认为显式命名的函数比字符串插值语法更容易混淆。

理查德小胖 2020.03.17

这是我使用的解决方案,以下说明:

@mixin transition($trans...) {
  @if length($trans) < 1 {
    $trans: all .15s ease-out;
  }
  -moz-transition: $trans;
  -ms-transition: $trans;
  -webkit-transition: $trans;
  transition: $trans;
}

.use-this {
  @include transition;
}

.use-this-2 {
  @include transition(all 1s ease-out, color 2s ease-in);
}
  • 宁愿将属性值作为本地css传递,以保持接近“舌头”
  • 允许传递可变数量的参数
  • 定义懒惰的默认值
神奇Pro 2020.03.17

我知道它不是您正在寻找的答案,但是您可以"null"在进行@include box-shadow混合时作为最后一个参数传递,就像@include box-shadow(12px, 14px, 2px, green, null);现在这样,如果那个参数在该属性中只有一个,则该属性(及其(默认)值)不会被编译。如果该“行”上有两个或多个参数,则只有您为空的参数才会被编译(您的情况)。

CSS输出完全如您所愿,但是您必须编写nulls :)

  @include box-shadow(12px, 14px, 2px, green, null);

  // compiles to ...

  -webkit-box-shadow: 12px 14px 2px green;  
  -moz-box-shadow: 12px 14px 2px green;  
  box-shadow: 12px 14px 2px green;
理查德GO 2020.03.17

Sass支持@if语句。(请参阅文档。)

您可以这样编写mixin:

@mixin box-shadow($top, $left, $blur, $color, $inset:"") {
  @if $inset != "" {
    -webkit-box-shadow:$top $left $blur $color $inset;
    -moz-box-shadow:$top $left $blur $color $inset;
    box-shadow:$top $left $blur $color $inset;
  }
}
斯丁JimDavaid 2020.03.17

您可以将属性null设置为默认值,如果不传递该参数,它将不会被解释。

@mixin box-shadow($top, $left, $blur, $color, $inset:null) {
  -webkit-box-shadow: $top $left $blur $color $inset;
  -moz-box-shadow:    $top $left $blur $color $inset;
  box-shadow:         $top $left $blur $color $inset;
}

这意味着您可以这样编写include语句。

@include box-shadow($top, $left, $blur, $color);

而不是像这样写。

@include box-shadow($top, $left, $blur, $color, null);

如图答案在这里

老丝梅 2020.03.17

更好的干法

是传递$args...给的@mixin这样,无论$args您要通过多少次。@input通话中,您可以传递所有需要的参数。像这样:

@mixin box-shadow($args...) {
  -webkit-box-shadow: $args;
  -moz-box-shadow: $args;
  box-shadow: $args;
}

现在,您可以通过传递所有需要的参数,在每个所需的类中重用盒子阴影:

.my-box-shadow {
  @include box-shadow(2px 2px 5px #555, inset 0 0 0);
}
乐猴子 2020.03.17

一种干燥的方式

而且,通常,这是删除引号的巧妙方法。

@mixin box-shadow($top, $left, $blur, $color, $inset:"") {
  -webkit-box-shadow: $top $left $blur $color #{$inset};
  -moz-box-shadow:    $top $left $blur $color #{$inset};
  box-shadow:         $top $left $blur $color #{$inset};
}

SASS版本3+,您可以使用unquote()

@mixin box-shadow($top, $left, $blur, $color, $inset:"") {
  -webkit-box-shadow: $top $left $blur $color unquote($inset);
  -moz-box-shadow:    $top $left $blur $color unquote($inset);
  box-shadow:         $top $left $blur $color unquote($inset);
} 

在这里进行选择:使用SASS作为单个参数将列表传递给mixin

问题类别

JavaScript Ckeditor Python Webpack TypeScript Vue.js React.js ExpressJS KoaJS CSS Node.js HTML Django 单元测试 PHP Asp.net jQuery Bootstrap IOS Android