若是编译器在mixin调用中或者是声明中看到至少一个分号,那么假设这个歌参数用分号分隔的话,而且全部逗号都属于css列表,咱们能够有如下几种状况:css
.name(1, 2, 3; something, else)
.name(1, 2, 3)
.name(1, 2, 3;)
.name(@param1: red, blue;)
mixin引用时能够经过名称而不是位置来提供参数值,能够经过名称来引用任何参数任何参数均可以经过它的名称来引用,而不是特定的顺序 。web
.mixin(@color: green; @font-size: 18px; @padding: 15px; @margin: 10px;) { color: @color; font-size: @font-size; padding: @padding; margin: @margin; } .name1 { .mixin( @color: blue; @margin: 20px;); } .name2 { .mixin(red; @padding: 30px; @font-size:40px;); } // 输出,改变后的值改变,没有从新赋值的值默认原值 .name1 { color: blue; font-size: 18px; padding: 15px; margin: 20px; } .name2 { color: red; padding: 30px; font-size:40px; margin: 10px; }
@arguments
在JavaScript中表明全部的参数,在mixin内部一样有特殊含义,它包含调用mixin时传递的全部参数;若是咱们不想处理单个参数,它将会很是适用。rest
.box-shadow(@x: 0; @y: 0; @blur: 20px; @color: green) { -webkit-box-shadow: @arguments; -moz-box-shadow: @arguments; box-shadow: @arguments; } .argVar { .box-shadow(2px; 11px); } // 输出 .argVar { -webkit-box-shadow: 2px 11px 20px green; -moz-box-shadow: 2px 11px 20px green; box-shadow: 2px 11px 20px green; }
...
若是您但愿mixin接受可变数量的参数,则可使用。在变量名以后使用此命令会将这些参数分配给变量。code
// 1:匹配0-n参数 .mixin(...) {} // 2:彻底匹配0个参数 .mixin() {} // 3:匹配0-1个参数 .mixin(@a: 1) {} // 4:匹配0-n参数 .mixin(@a: 1; ...) {} // 5:匹配1-n个参数 .mixin(@a; ...) {}
经过将参数传递给它来改变mixin的行为。ip