Less参数混合

Mixins 具备多个参数

  • 参数可使用逗号或分号分隔。 (建议使用分号,由于逗号具备双重含义:能够将其解释为mixin参数分隔符或者是css列表分隔符);使用逗号做为mixin分隔符使不可能建立逗号分隔的列表做为参数。
  • 参数mixin使用一个或多个参数,经过参数和它的属性来扩展Less的功能,以达到在混合到另外一个块时自定义mixin输出的效果。
  • 若是编译器在mixin调用中或者是声明中看到至少一个分号,那么假设这个歌参数用分号分隔的话,而且全部逗号都属于css列表,咱们能够有如下几种状况:css

    • 两个参数,每个包含逗号分隔的列表:.name(1, 2, 3; something, else)
    • 三个参数,而且每一个包含一个数字:.name(1, 2, 3)
    • 使用虚拟分号建立混入调用一个参数包含逗号分隔的CSS列表:.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 变量

@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;
    }

高级参数和@rest变量

... 若是您但愿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

相关文章
相关标签/搜索