Less 09 守卫(Guards)

2019-10-04  本文已影响0人  Sommouns

目录:

Less 01 准备工作
Less 02 变量(Variable)
Less 03 扩展(Extend)
Less 04 混入(Mixins)
Less 05 参数混入(Parametric Mixins)
Less 06 方法混入 (Mixins as Functions)
Less 07 CssRules 直接混入(Passing Rulesets to Mixins)
Less 08 导入(Import)
Less 09 守卫(Guards)
Less 10 其他操作(完结)

Mixin Guards

mixin可以像其他编程语言那样,使用判断,比如这样

.mixin (@a) when (lightness(@a) >= 50%) {
  background-color: black;
}
.mixin (@a) when (lightness(@a) < 50%) {
  background-color: white;
}
.mixin (@a) {
  color: @a;
}

运行

.class1 { .mixin(#ddd) }
.class2 { .mixin(#555) }

输出

.class1 {
  background-color: black;
  color: #ddd;
}
.class2 {
  background-color: white;
  color: #555;
}

操作符

>,>=,=,=<,<,true是唯一的真值,下面是等价的

.truth (@a) when (@a) { ... }
.truth (@a) when (@a = true) { ... }

.class {
  .truth(40); // Will not match any of the above definitions.
}

当然还能比较arguments

@media: mobile;

.mixin (@a) when (@media = mobile) { ... }
.mixin (@a) when (@media = desktop) { ... }

.max (@a; @b) when (@a > @b) { width: @a }
.max (@a; @b) when (@a < @b) { width: @b }

守卫逻辑运算符

and

.mixin (@a) when (isnumber(@a)) and (@a > 0) { ... }

,

.mixin (@a) when (@a > 10), (@a < -10) { ... }

not

.mixin (@b) when not (@b > 0) { ... }

类型检测

如果你想根据传入参数的类型匹配mixin,可以使用is开头的函数

基础类型检测

单位检测

条件判断

default类似我们js中if else中的else

.mixin (@a) when (@a > 0) { ...  }
.mixin (@a) when (default()) { ... } // matches only if first mixin does not, i.e. when @a <= 0

Css Guard

在v1.5.0之后
可以这样写

button when (@my-option = true) {
  color: white;
}

如果要绑定多个guards

& when (@my-option = true) {
  button {
    color: white;
  }
  a {
    color: blue;
  }
}

最后强调一个单位不同问题,计算的话,他不管单位的,全当数字来计算,然后就是返回的单位以第一个参数为准

上一篇 下一篇

猜你喜欢

热点阅读