cla*_*uzy 104 conditional if-statement sass mixins
嗨,我正在尝试学习SASS/SCSS,并试图重构我自己的mixin for clearfix
我想要的是mixin是基于我是否通过mixin宽度.
到目前为止的想法(伪代码,因为我将包括其他mixins)
@mixin clearfix($width) {
@if !$width {
// if width is not passed, or empty do this
} @else {
display: inline-block;
width: $width;
}
}
Run Code Online (Sandbox Code Playgroud)
这就是我以为我可以称之为它,但它不起作用.
@include clearfix();
要么
@include clearfix(100%)
要么
@include clearfix(960px)
我会感谢任何有关最佳或正确方法的帮助!
小智 219
首次创建mixin时,可以内联指定默认参数值:
@mixin clearfix($width: 'auto') {
@if $width == 'auto' {
// if width is not passed, or empty do this
} @else {
display: inline-block;
width: $width;
}
}
Run Code Online (Sandbox Code Playgroud)
sim*_*mes 141
你可以试试这个:
$width:auto;
@mixin clearfix($width) {
@if $width == 'auto' {
// if width is not passed, or empty do this
} @else {
display: inline-block;
width: $width;
}
}
Run Code Online (Sandbox Code Playgroud)
我不确定您的预期结果,但设置默认值应该返回false.
Que*_*ron 12
您可以将参数默认为null或false。
这样,测试值是否已作为参数传递会更短。
@mixin clearfix($width: null) {
@if not ($width) {
// if width is not passed, or empty do this
} @else {
display: inline-block;
width: $width;
}
}
Run Code Online (Sandbox Code Playgroud)