ChatGPT解决这个技术问题 Extra ChatGPT

SCSS mixin 中 if/else 条件的语法

嗨,我正在尝试学习 SASS/SCSS,并尝试为 clearfix 重构我自己的 mixin

我想要的是混合基于我是否通过混合宽度。

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

@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)

对于最好或正确的方法,我将不胜感激!


r
rmNyro

您可以在首次创建 mixin 时内联分配默认参数值:

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

  @if $width == 'auto' {

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

  } @else {

    display: inline-block;
    width: $width;

  }
}

r
rmNyro

你可以试试这个:

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

   @if $width == 'auto' {

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

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

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


确实如此,谢谢我使用 " ",但我更喜欢 auto 值:) - 尽管我将它放在 mixin 语法中作为默认值 @mixin clearfix($width: auto) {...,但不需要设置变量谢谢 :)
是否有任何目的给予 $width:auto;作为默认值?
Q
Quentin Veron

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

@mixin clearfix($width: null) {

  @if not ($width) {

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

  } @else {

    display: inline-block;
    width: $width;

  }
}