SASS 和 LESS 的区别

2019-08-23 22:50:38 浏览数 (1)

1、编译环境不同

SASS 的安装需要 Ruby 环境,是在服务端处理的;

LESS 需要引入 less.js 来处理代码输出 CSS 到浏览器,也可以在开发环节使用 LESS,然后编译成 CSS 文件直接使用

2、变量符不同

SASS 变量符是 $

LESS 变量符是 @

3、变量作用域不同

> SASS 作用域

代码语言:javascript复制
$color: blue;

#header{
  $color:red;
  border:1px solid $color;
}

#footer{
  border:1px solid $color;
}

用 SASS 编译后

代码语言:javascript复制
#header{border:1px solid red}
#footer{border:1px solid red}

> LESS 作用域

代码语言:javascript复制
@color: blue;

#header{
  @color:red;
  border:1px solid @color;
}

#footer{
  border:1px solid @color;
}

用 LESS 编译后

代码语言:javascript复制
#header{border:1px solid red;}
#footer{border:1px solid blue;}

可以看出,less 和 scss 中的变量会随着作用域的变化而不同

4、SASS 支持条件语句(if、else、for等等),而 LESS 不支持

代码语言:javascript复制
/*Sample Sass “if” statement*/
@if lightness($color) > 30%{
    ...
}
@else{
  ...
}

5、引用外部 CSS 文件

scss 引用的外部文件命名必须以_开头, 如下例所示:

代码语言:javascript复制
// 源代码:
@import "_test1.scss";
@import "_test2.scss";

// 编译后:
h1{
  font-size:17px;
}
h2{
  font-size:17px;
}

其中_test1.scss、_test2.scss文件分别设置的h1 h2。文件名如果以下划线_开头的话,Sass会认为该文件是一个引用文件,不会将其编译为css文件.

而 Less 引用外部文件和 css 中的 @import 没什么区别

6、工具库不同

Sass 有工具库 Compass, 在其基础上封装了一系列有用的模块和模板,补充强化了Sass的功能;

Less 有 UI 组件库 Bootstrap。

0 人点赞