浅析Sass Scss Less

Sass 与 Scss 的区别

最开始,Sass 是Haml的一部分,Haml 是一种预处理器,由 Ruby 开发者设计和开发。因为这样,Sass 使用类似 Ruby的语法,没有

花括号,没有分号,具有严格的缩进,依赖Ruby进行编译。在20105月,为了更好的服务于css的语法操作,更新为Scss;Scss与css

的语法相似可以更简洁的服务于前端开发人员。

Sass与Scss的分别主要在以下两点:  

1. 变量的定义不同:在Sass中是以 !color 来定义,而在Scss中是以 $color来定义;

2. 混合宏的定义不同:

        在Sass中 ---
                // Mixin
                =border-radius(!radius)
                    -webkit-border-radius= !radius
                    -moz-border-radius= !radius
                    border-radius= !radius
                // 调用
                .my-other-element
                    +border-radius(5px)
         在Scss中 ---
                 // Mixin
                @mixin border-radius($radius) {
                    -webkit-border-radius: $radius;
                    -moz-border-radius: $radius;
                    border-radius: $radius;
                }
                //调用
                .my-other-element {
                    @include border-radius(5px);
                }

3.表示层级关系的东西不同:在Sass中以缩进和换行,在Scss中以{}和;

Sass/Scss 与 Less 的区别

1.编译的环境不同:

Sass的安装需要Ruby环境,是在服务端处理的,而Less是需要引入less.js来处理Less代 码输出css到浏览器,也可以在开发环节使用

Less,然后编译成css文件,直接放到项目中,也有 Less.app、SimpleLess、CodeKit.app这样的工具,也有在线编译地址。

2.变量符不一样,Less是@,而Scss是$,而且变量的作用域也不一样。

Less-作用域
@color: #00c; /* 蓝色 */
#header {
  @color: #c00; /* red */
  border: 1px solid @color; /* 红色边框 */
}

#footer {
  border: 1px solid @color; /* 蓝色边框 */
}

Less-作用域编译后
#header{border:1px solid #cc0000;}
#footer{border:1px solid #0000cc;}

scss-作用域
$color: #00c; /* 蓝色 */

#header {

  $color: #c00; /* red */
  border: 1px solid $color; /* 红色边框 */
}

#footer {
  border: 1px solid $color; /* 蓝色边框 */
}

Sass-作用域编译后

#header{border:1px solid #c00}
#footer{border:1px solid #c00}

我们可以看出来,less和scss中的变量会随着作用域的变化而不一样。

3.输出设置,Less没有输出设置,Sass提供4中输出选项:nested, compact, compressed 和 expanded。
输出样式的风格可以有四种选择,默认为nested

· nested:嵌套缩进的css代码
· expanded:展开的多行css代码
· compact:简洁格式的css代码
· compressed:压缩后的css代码 

4.Sass支持条件语句,可以使用if{}else{},for{}循环等等。而Less不支持。

/* Sample Sass “if” statement */

@if lightness($color) > 30% {

} @else {

}

/* Sample Sass “for” loop */

@for $i from 1 to 10 {
  .border-#{$i} {
    border: #{$i}px solid blue;
  }
}

5.引用外部CSS文件

  • scss引用的外部文件命名必须以_开头, 如下例所示:其中_test1.scss、_test2.scss、_test3.scss文件分别设置的h1 h2 h3。文件名如果以下划线_开头的话,Sass会认为该文件是一个引用文件,不会将其编译为css文件.
  • Less引用外部文件和css中的@import没什么差异。

6.Sass和Less的工具库不同

Sass有工具库Compass, 简单说,Sass和Compass的关系有点像Javascript和jQuery的关系,Compass是Sass的工具库。在它的基础上,

封装了一系列有用的模块和模板,补充强化了Sass的功能。Less有UI组件库Bootstrap,Bootstrap是web前端开发中一个比较有名的前端

UI组件库,Bootstrap的样式文件部分源码就是采用Less语法编写

猜你喜欢

转载自blog.csdn.net/zq_king/article/details/80348662