2

我有以下混合:

.iconFont(@color: @green, @font-size: 18px){
  color: @color;
  font-size: @font-size;
}

如果我只想改变第二个变量的值,我需要写第一个变量的默认值吗?

h1{
 .iconFont(@green, 14px);
}
4

1 回答 1

5

不,调用函数时无需指定第一个参数的默认值。相反,您可以使用命名参数功能显式地让编译器知道您在 mixin 调用中传递的值是用于第二个参数的。

.sample{
    .iconFont(@font-size:14px);
}

上面的 Less 代码在编译时会产生下面的输出。(注意:我已将 as 设置@green#00ff00。)

.sample {
    color: #00ff00;
    font-size: 14px;
}

在使用命名参数功能时,即使参数传递的顺序也无关紧要。例如,可以如下调用相同的 mixin:

.sample2{
    .iconFont(@font-size:24px, @color: #070707);
}

它会产生以下输出。

.sample2 {
    color: #070707;
    font-size: 24px;
}
于 2014-09-11T13:01:50.317 回答