CSS 预处理器是一种语言用来为 CSS 增加一些编程的的特性,无需考虑浏览器的兼容性问题,例如你可以在 CSS 中使用变量、简单的程序逻辑、函数等等在编程语言中的一些基本技巧,可以让CSS 更见简洁,适应性更强,代码更直观等诸多好处。
h1 {
color: #0982C1;
}
h1
color: #0982c1
h1
color #0982C1
在less文件中,当一个值需要反复使用时,可以通过@符号定义变量。已经被赋值的变量以及其他的常量(如像素、颜色等)都可以参与运算。
Less css中变量都是用@开头的,然后变量和值之间使用冒号(:)隔开,和css属性是一样的,例如:
@maincolor : #092873;
@siteWidth : 1024px;
@borderStyle : dotted;
body {
color: @maincolor;
border: 1px @borderStyle @mainColor;
max-width: @siteWidth;
}
Sass让人们受益的一个重要特性就是它为css引入了变量。你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属性值。
sass变量必须是以$开头的,然后变量和值之间使用冒号(:)隔开,和css属性是一样的,例如:
$maincolor : #092873;
$siteWidth : 1024px;
$borderStyle : dotted;
body {
color: $maincolor;
border: 1px $borderStyle $mainColor;
max-width: $siteWidth;
}
stylus对变量是没有任何设定的,可以是以$开头,或者任何的字符,而且与变量之间可以用冒号,空格隔开,
但是在stylus中不能用@开头,例如:
maincolor = #092873
siteWidth = 1024px
borderStyle = dotted
body
color maincolor
border 1px borderStyle mainColor
max-width siteWidth
以上三种写法都如同一下这种css:
body {
color: #092873;
border: 1px dotted #092873;
max-width: 1024px;
}
这样做的好处也是显而易见的,在修改多处相同颜色的时候,这时就只需要修改变量值即可。
三个 CSS 框架都是允许嵌套语法
section {
margin: 10px;
nav {
height: 25px;
a {
color: #0982C1;
&:hover {
text-decoration: underline;
}
}
}
}
最终编译的结果就是
section {
margin: 10px;
}
section nav {
height: 25px;
}
section nav a {
color: #0982C1;
}
section nav a:hover {
text-decoration: underline;
}
在 CSS 预处理器中还是可以进行样式的计算如下:
body {
margin: (14px/2);
top: 50px + 100px;
right: 80 * 10%;
left:100px-50px;
}
sass可通过@extend来实现代码组合声明,使代码更加优越简洁。
.message {
border: 1px solid #ccc;
padding: 10px;
color: #333;
}
.success {
@extend .message;
border-color: green;
}
stylus同样也是通过@extend
.message {
padding: 10px;
border: 1px solid #eee;
}
.warning {
@extend .message;
color: #E2E21E;
}
Less 表现的稍微弱一些,更像是混入写法:
.message {
border: 1px solid #ccc;
padding: 10px;
color: #333;
}
.success {
.message;
border-color: green;
}
Mixins 有点像是函数或者是宏,当某段 CSS 经常需要在多个元素中使用时,可以为这些共用的 CSS 定义一个 Mixin,然后只需要在需要引用这些 CSS 地方调用该 Mixin 即可。
sass中可用mixin定义一些代码片段,且可传参数,方便日后根据需求调用。
@mixin error($borderWidth: 2px) {
border: $borderWidth solid #F00;
color: #F00;
}
.generic-error {
padding: 20px;
margin: 4px;
@ include error(); //这里调用默认 border: 2px solid #F00;
}
.login-error {
left: 12px;
position: absolute;
top: 20px;
@ include error(5px); //这里调用 border:5px solid #F00;
}
less也支持带参数的混合以及有默认参数值的混合,如下面的例子所示:
.error(@borderWidth: 2px) {
border: @borderWidth solid #F00;
color: #F00;
}
.generic-error {
padding: 20px;
margin: 4px;
.error(); //这里调用默认 border: 2px solid #F00;
}
.login-error {
left: 12px;
position: absolute;
top: 20px;
.error(5px); //这里调用 border:5px solid #F00;
}
error(borderWidth= 2px) {
border: borderWidth solid #F00;
color: #F00;
}
.generic-error {
padding: 20px;
margin: 4px;
error();
}
.login-error {
left: 12px;
position: absolute;
top: 20px;
error(5px);
}
他们最终呈现的效果都如下:
.generic-error {
padding: 20px;
margin: 4px;
border: 2px solid #f00;
color: #f00;
}
.login-error {
left: 12px;
position: absolute;
top: 20px;
border: 5px solid #f00;
color: #f00;
}
很多 CSS 开发者对导入的做法都不太感冒,因为它需要多次的 HTTP 请求。但是在 CSS 预处理器中的导入操作则不同,它只是在语义上包含了不同的文件,但最终结果是一个单一的 CSS 文件,如果你是通过 @ import “file.css”; 导入 CSS 文件,那效果跟普通的 CSS 导入一样。
注意:导入文件中定义的混入、变量等信息也将会被引入到主样式文件中,因此需要避免它们互相冲突。
例如:
//1.css
/* file.{type} */
body {
background: #000;
}
8.2 XXX:
@ import “1.css”;
@ import “file.{type}”;
p {
background: #092873;
}
最终生成的 CSS:
@ import “1.css”;
body {
background: #000;
}
p {
background: #092873;
}
Sass if 有两种,第一种是 if() 函数,第二种便是 @if 指令。
如果指令的表达式为真,那么久输出值,否则就不输出。当然也有 @else if 和 @else。
条件表达式不需要括号
@if可一个条件单独使用,也可以和@else结合多条件使用
$lte7: true;
$type: monster;
.ib{
display:inline-block;
@if $lte7 {
*display:inline;
*zoom:1;
}
}
p {
@if $type == ocean {
color: blue;
} @else if $type == matador {
color: red;
} @else if $type == monster {
color: green;
} @else {
color: black;
}
}
其最终的css代码如下:
.ib{
display:inline-block;
*display:inline;
*zoom:1;
}
p {
color: green;
}
for循环有两种形式,分别为:
1.@for $var from through
2.@for varfrom
。
12其中i表示变量,start表示起始值,end表示结束值,这两个的区别是关键字through表示包括end这个数,而to则不包括end这个数。
@for KaTeX parse error: Expected '}', got '#' at position 26: …o 10 { .border-#̲{i} {
border: #{$i}px solid blue;
}
}
同时也支持while循环:
$i: 6;
@while KaTeX parse error: Expected '}', got '#' at position 15: i > 0 { .item-#̲{i} { width: 2em * $i; }
$i: $i - 2;
}
最后,同时支持each命令,作用与for类似:
$animal-list: puma, sea-slug, egret, salamander;
@each $animal in KaTeX parse error: Expected '}', got '#' at position 16: animal-list { .#̲{animal}-icon {
background-image: url(’/images/#{$animal}.png’);
}
}
其css最终效果如下:
.puma-icon {
background-image: url(’/images/puma.png’);
}
.sea-slug-icon {
background-image: url(’/images/sea-slug.png’);
}
.egret-icon {
background-image: url(’/images/egret.png’);
}
.salamander-icon {
background-image: url(’/images/salamander.png’);
}
Less 没有直接对应的东西,但是他有一个 Guard 的概念,可以认为是变种的 if。通过在某些选择器、Mixin 定义后面添加 when (condition)。只有当 condition 为真的时候,相应的选择器、Mixin 才会起作用。
Less 首先大家要清楚,Less 中的变量都是懒加载的所,他无法实现循环中对变量的有效控制,所以他支持 Mixin 内调用自己,也即是说通过 Guard 和 Pattern Matching 通过递归实现循环。
for [, ] in 。
就跟普通的 JS 语句一样。和 if 语句类似,他也支持后缀表达式。但是如果 express 是 Hashes,那么表达式相应的变为 for , in