头闻号

上海博田装饰工程有限公司

环氧树脂|聚氨酯树脂|其他工程承包|建筑涂料|防水、防潮材料|其他未分类

首页 > 新闻中心 > 科技常识:Less参数混合
科技常识:Less参数混合
发布时间:2024-09-22 08:34:16        浏览次数:2        返回列表

今天小编跟大家讲解下有关Less参数混合 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关Less参数混合 的相关资料,希望小伙伴们看了有所帮助。

Mixins 具有多个参数

*参数可以使用逗号或分号分隔。 (建议使用分号,因为逗号具有双重含义:可以将其解释为mixin参数分隔符或者是css列表分隔符);使用逗号作为mixin分隔符使不可能创建逗号分隔的列表作为参数。

参数mixin使用一个或多个参数,通过参数和它的属性来扩展Less的功能,以达到在混合到另一个块时自定义mixin输出的效果。如果编译器在mixin调用中或者是声明中看到至少一个分号,那么假设这个歌参数用分号分隔的话,并且所有逗号都属于css列表,我们可以有以下几种情况:两个参数,每一个包含逗号分隔的列表:.name(1, 2, 3; something, else)三个参数,并且每个包含一个数字:.name(1, 2, 3)使用虚拟分号创建混入调用一个参数包含逗号分隔的css列表:.name(1, 2, 3;)逗号分隔的默认值:.name(@param1: red, blue;)

命名参数

mixin引用时可以通过名称而不是位置来提供参数值,可以通过名称来引用任何参数任何参数都可以通过它的名称来引用,而不是特定的顺序 。

.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; [email protected] 变量

@arguments在Javascript中代表所有的参数,在mixin内部同样有特殊含义,它包含调用mixin时传递的所有参数;如果我们不想处理单个参数,它将会非常适用。

.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; [email protected]

...如果您希望mixin接受可变数量的参数,则可以使用。在变量名之后使用此命令会将这些参数分配给变量。

// 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的行为。

来源:爱蒂网