AI智能
改变未来

CSS预处理器sass/less/stylus的区别

CSS预处理器less/sass/stylus的区别

  • 1.什么是 CSS 预处理器
  • 2.基本的写法区别
  • 2.1 less: 标准的css语法 ,有花括号和冒号
  • 2.2 sass: 可以写成上面那样 同时也可以不写花括号
  • 2.3 stylus: 花括号和冒号都可以不写 比较自由
  • 3. 变量上的差异
    • 3.1 Less
    • 3.2 sass
    • 3.3.stylus:
  • 4.嵌套
  • 5.运算符
  • 6.继承
    • 6.1 sass:
    • 6.2 stylus
    • 6.3 less
  • 7.Mixins(混入)
    • 7.1 Sass 的混入语法:
    • 7.2 Less CSS 的混入语法:
    • 7.3 Stylus 的混入语法:
  • 8 导入import
    • 8.1 css:
  • 9. 控制语句 Controls
    • 9.1 在sass中,还支持条件语句:
    • 9.2除却条件语句,sass还支持for循环:
    • 9.3 less
    • 9.3 stylus

    1.什么是 CSS 预处理器

    CSS 预处理器是一种语言用来为 CSS 增加一些编程的的特性,无需考虑浏览器的兼容性问题,例如你可以在 CSS 中使用变量、简单的程序逻辑、函数等等在编程语言中的一些基本技巧,可以让CSS 更见简洁,适应性更强,代码更直观等诸多好处。

    2.基本的写法区别

    2.1 less: 标准的css语法 ,有花括号和冒号

    h1 {color: #0982C1;}

    2.2 sass: 可以写成上面那样 同时也可以不写花括号

    h1color: #0982c1

    2.3 stylus: 花括号和冒号都可以不写 比较自由

    h1color #0982C1

    3. 变量上的差异

    3.1 Less

    在less文件中,当一个值需要反复使用时,可以通过@符号定义变量。已经被赋值的变量以及其他的常量(如像素、颜色等)都可以参与运算。

    Less css中变量都是用@开头的,然后变量和值之间使用冒号(:)隔开,和css属性是一样的,例如:

    @maincolor : #092873;@siteWidth : 1024px;@borderStyle : dotted;body {color: @maincolor;border: 1px @borderStyle @mainColor;max-width: @siteWidth;}

    3.2 sass

    Sass让人们受益的一个重要特性就是它为css引入了变量。你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属性值。
    sass变量必须是以$开头的,然后变量和值之间使用冒号(:)隔开,和css属性是一样的,例如:

    $maincolor : #092873;$siteWidth : 1024px;$borderStyle : dotted;body {color: $maincolor;border: 1px $borderStyle $mainColor;max-width: $siteWidth;}

    3.3.stylus:

    stylus对变量是没有任何设定的,可以是以$开头,或者任何的字符,而且与变量之间可以用冒号,空格隔开,
    但是在stylus中不能用@开头,例如:

    maincolor = #092873siteWidth = 1024pxborderStyle = dottedbodycolor maincolorborder 1px borderStyle mainColormax-width siteWidth以上三种写法都如同一下这种css:body {color: #092873;border: 1px dotted #092873;max-width: 1024px;}

    这样做的好处也是显而易见的,在修改多处相同颜色的时候,这时就只需要修改变量值即可。

    4.嵌套

    三个 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;}

    5.运算符

    在 CSS 预处理器中还是可以进行样式的计算如下:

    body {margin: (14px/2);top: 50px + 100px;right: 80 * 10%;left:100px-50px;}

    6.继承

    6.1 sass:

    sass可通过@extend来实现代码组合声明,使代码更加优越简洁。

    .message {border: 1px solid #ccc;padding: 10px;color: #333;}.success {@extend .message;border-color: green;}

    6.2 stylus

    stylus同样也是通过@extend

    .message {padding: 10px;border: 1px solid #eee;}.warning {@extend .message;color: #E2E21E;}

    6.3 less

    Less 表现的稍微弱一些,更像是混入写法:

    .message {border: 1px solid #ccc;padding: 10px;color: #333;}.success {.message;border-color: green;}

    7.Mixins(混入)

    Mixins 有点像是函数或者是宏,当某段 CSS 经常需要在多个元素中使用时,可以为这些共用的 CSS 定义一个 Mixin,然后只需要在需要引用这些 CSS 地方调用该 Mixin 即可。

    7.1 Sass 的混入语法:

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

    7.2 Less CSS 的混入语法:

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

    7.3 Stylus 的混入语法:

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

    8 导入import

    很多 CSS 开发者对导入的做法都不太感冒,因为它需要多次的 HTTP 请求。但是在 CSS 预处理器中的导入操作则不同,它只是在语义上包含了不同的文件,但最终结果是一个单一的 CSS 文件,如果你是通过 @ import “file.css”; 导入 CSS 文件,那效果跟普通的 CSS 导入一样。

    注意:导入文件中定义的混入、变量等信息也将会被引入到主样式文件中,因此需要避免它们互相冲突。
    例如:

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

    9. 控制语句 Controls

    9.1 在sass中,还支持条件语句:

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

    9.2除却条件语句,sass还支持for循环:

    for循环有两种形式,分别为:

    1.@for $var from through
    2.@for varfrom

    <start> to<end>


    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’);}

    9.3 less

    • Less 没有直接对应的东西,但是他有一个 Guard 的概念,可以认为是变种的 if。通过在某些选择器、Mixin 定义后面添加 when (condition)。只有当 condition 为真的时候,相应的选择器、Mixin 才会起作用。

    • Less 首先大家要清楚,Less 中的变量都是懒加载的所,他无法实现循环中对变量的有效控制,所以他支持 Mixin 内调用自己,也即是说通过 Guard 和 Pattern Matching 通过递归实现循环。

    9.3 stylus

    • Stylus if/else 跟普通编程语言几乎是一模一样的,也可以嵌套,这里就不多讲了。不过 Stylus 还有一个 unless ,就是 if 加了 !,其他都是一样的。也支持后添加的条件表达式,类似于 CoffeeScript 和 Ruby。条件表达式不需要括号
    • Stylus 简单来说就一个
      for <val-name> [, <index-name>] in <expression>。

      就跟普通的 JS 语句一样。和 if 语句类似,他也支持后缀表达式。但是如果 express 是 Hashes,那么表达式相应的变为

      for <key-name>, <value-name> in <hashes>
    赞(0) 打赏
    未经允许不得转载:爱站程序员基地 » CSS预处理器sass/less/stylus的区别