SCSS mixin中if / else条件的语法

时间:2011-03-28 08:36:59

标签: conditional mixins sass if-statement

您好我正在尝试学习SASS / SCSS并尝试重构我自己的mixin for clearfix

我想要的是mixin基于我是否通过了一个宽度的混音。

到目前为止的想法(伪代码,因为我将包括其他mixins)

@mixin clearfix($width) {

   @if !$width {

    // if width is not passed, or empty do this

   } @else {

        display: inline-block;
        width: $width;
   }
}

这就是我以为我可以称之为它的方式,但它不起作用。

@include clearfix();

@include clearfix(100%)

@include clearfix(960px)

我很感谢您在最佳或正确的方式上提供任何帮助!

3 个答案:

答案 0 :(得分:208)

首次创建mixin时,您可以内联指定默认参数值:

@mixin clearfix($width: 'auto') {

  @if $width == 'auto' {

    // if width is not passed, or empty do this

  } @else {

    display: inline-block;
    width: $width;

  }
}

答案 1 :(得分:136)

你可以试试这个:

$width:auto;
@mixin clearfix($width) {

   @if $width == 'auto' {

    // if width is not passed, or empty do this

   } @else {
        display: inline-block;
        width: $width;
   }
}

我不确定您的预期结果,但设置默认值应返回false。

答案 2 :(得分:2)

您可以将参数默认设置为nullfalse
这样,测试值是否已作为参数传递将更短。

@mixin clearfix($width: null) {

  @if not ($width) {

    // if width is not passed, or empty do this

  } @else {

    display: inline-block;
    width: $width;

  }
}