CSS 预处理器技术已经非常的成熟了,而且也涌现出了越来越多的 CSS 的预处理器框架。本文便总结下 Sass、Less CSS、Stylus这三个预处理器的区别和各自的基本语法。

1.什么是 CSS 预处理器

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

2.基本语法区别:

在使用 CSS 预处理器之前最重要的是理解语法,幸运的是基本上大多数预处理器的语法跟 CSS 都差不多。

首先 Sass 和 Less 都使用的是标准的 CSS 语法,因此如果可以很方便的将已有的 CSS 代码转为预处理器代码,默认 Sass 使用 .sass 扩展名,而 Less 使用 .less 扩展名。

/* style.scss or style.less */
h1 {color: #0982C1;
}

这是一个再普通不过的,不过 Sass 同时也支持老的语法,就是不包含花括号和分号的方式:

/* style.sass */
h1color: #0982c1

而 Stylus 支持的语法要更多样性一点,它默认使用 .styl 的文件扩展名,下面是 Stylus 支持的语法:

/* style.styl */
h1 {color: #0982C1;
}/* omit brackets */
h1color: #0982C1;/* omit colons and semi-colons */
h1color #0982C1

可以在同一个样式单中使用不同的变量,例如下面的写法也不会报错:

h1 {color #0982c1
}
h2font-size: 1.2em

3.变量

1. sass:

Sass让人们受益的一个重要特性就是它为css引入了变量。你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属性值。

     sass变量必须是以$开头的,然后变量和值之间使用冒号(:)隔开,和css属性是一样的,例如:
$maincolor : #092873;
$siteWidth : 1024px;
$borderStyle : dotted;
body {color: $maincolor;border: 1px $borderStyle $mainColor;max-width: $siteWidth;
}

2.less css :

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

 Less css中变量都是用@开头的,其余与sass都是一样的,例如:
@maincolor : #092873;
@siteWidth : 1024px;
@borderStyle : dotted;
body {color: @maincolor;border: 1px @borderStyle @mainColor;max-width: @siteWidth;
}

3.stylus:

 stylus对变量是没有任何设定的,可以是以$开头,或者任何的字符,而且与变量之间可以用冒号,空格隔开,但是在stylus中不能用@开头,例如:
maincolor = #092873
siteWidth = 1024px
borderStyle = dotted
body color maincolorborder 1px borderStyle mainColormax-width siteWidth

以上三种写法都如同一下这种css:

body {color: #092873;border: 1px dotted #092873;max-width: 1024px;
}

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

4.嵌套

如果我们需要在CSS中相同的 parent 引用多个元素,这将是非常乏味的,你需要一遍又一遍地写 parent。例如:

div {margin: 10px;
}
div nav {height: 25px;
}
div nav a {color: #0982C1;
}
div nav a:hover {text-decoration: underline;
}

如果用 CSS 预处理器,就可以少写很多单词,而且父子节点关系一目了然,并且sass,Less,stylus都支持下面这样的写法,且都是相同的:

//scss style //-----------------------------------
nav { ul { margin: 0; padding: 0; } li { display: inline-block; } a { display: block; padding: 6px 12px; text-decoration: none; }
}
//css style //-----------------------------------
nav ul { margin: 0; padding: 0; list-style: none;
}
nav li { display: inline-block;
}
nav a { display: block; padding: 6px 12px; text-decoration: none;
}

这样做是非常方便的,也很直观。

5.运算符

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

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

在sass,Less与stylus中都是可以这样做的。

6.颜色函数

CSS 预处理器一般都会内置一些颜色处理函数用来对颜色值进行处理,例如加亮、变暗、颜色梯度等。

1.sass的颜色处理函数:

lighten($color, 10%);
darken($color, 10%);
saturate($color, 10%);
desaturate($color, 10%);
grayscale($color);
complement($color);
invert($color);
mix($color1, $color2, 50%); 

实例如下:

$color: #0982C1;
h1 {background: $color;border: 3px solid darken($color, 50%);
}

2.Less css颜色处理函数:

lighten(@color, 10%);
darken(@color, 10%);
saturate(@color, 10%);
desaturate(@color, 10%);
spin(@color, 10);
spin(@color, -10);
mix(@color1, @color2);

示例如下:

@color: #0982C1;
h1 {background: @color;border: 3px solid darken(@color, 50%);
}

3.Stylus颜色处理函数:

lighten(color, 10%);
darken(color, 10%);
saturate(color, 10%);
desaturate(color, 10%); 

示例如下;

color = #0982C1
h1background colorborder 3px solid darken(color, 50%)

7.导入 (Import)

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

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

//1.css
/* file.{type} */
body {background: #000;
}

2.XXX:

@ import "1.css";
@ import "file.{type}";p {background: #092873;
}

最终生成的 CSS:

@ import "1.css";
body {background: #000;
}
p {background: #092873;
}

8.继承

当我们需要为多个元素定义相同样式的时候,我们可以考虑使用继承的做法.

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

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

2.Less css:

但是在这方面 Less 表现的稍微弱一些,更像是混入写法:

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

上面两种写法其最终呈现的css样式都如下:

.message, .success, .error, .warning {border: 1px solid #cccccc;padding: 10px;color: #333;
}
.success {border-color: green;
}
.error {border-color: red;
}
.warning {border-color: yellow;
}

.message的样式将会被插入到相应的你想要继承的选择器中,但需要注意的是优先级的问题。

9.Mixins(混入)

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

1.Sass 的混入语法:

sass中可用mixin定义一些代码片段,且可传参数,方便日后根据需求调用。比如说处理css3浏览器前缀:

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

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

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

10.3D文本

要生成具有 3D 效果的文本可以使用 text-shadows ,唯一的问题就是当要修改颜色的时候就非常的麻烦,而通过 mixin 和颜色函数可以很轻松的实现:

1.sass:

@mixin text3d($color) {color: $color;text-shadow: 1px 1px 0px darken($color, 5%),2px 2px 0px darken($color, 10%),3px 3px 0px darken($color, 15%),4px 4px 0px darken($color, 20%),4px 4px 2px #000;
}h1 {font-size: 32pt;@ include text3d(#0982c1);
}

2.Less CSS:

.text3d(@color) {color: @color;text-shadow: 1px 1px 0px darken(@color, 5%),2px 2px 0px darken(@color, 10%),3px 3px 0px darken(@color, 15%),4px 4px 0px darken(@color, 20%),4px 4px 2px #000;
}span {font-size: 32pt;.text3d(#0982c1);
}

3.Stylus:

text3d(color)color: colortext-shadow: 1px 1px 0px darken(color, 5%), 2px 2px 0px darken(color, 10%), 3px 3px 0px darken(color, 15%), 4px 4px 0px darken(color, 20%), 4px 4px 2px #000
spanfont-size: 32pttext3d(#0982c1)

其生成的css最终的效果如下:

span {font-size: 32pt;color: #0982c1;text-shadow: 1px 1px 0px #097bb7,2px 2px 0px #0875ae,3px 3px 0px #086fa4,4px 4px 0px #07689a,4px 4px 2px #000;
}

11.列 (Columns)

使用数值操作和变量可以很方便的实现适应屏幕大小的布局处理。
1.Sass:

$siteWidth: 1024px;
$gutterWidth: 20px;
$sidebarWidth: 300px;
body {margin: 0 auto;width: $siteWidth;
}
.content {float: left;width: $siteWidth - ($sidebarWidth+$gutterWidth);
}
.sidebar {float: left;margin-left: $gutterWidth;width: $sidebarWidth;
}

2.Less CSS:

@siteWidth: 1024px;
@gutterWidth: 20px;
@sidebarWidth: 300px;body {margin: 0 auto;width: @siteWidth;
}
.content {float: left;width: @siteWidth - (@sidebarWidth+@gutterWidth);
}
.sidebar {float: left;margin-left: @gutterWidth;width: @sidebarWidth;
}

3.Stylus:

siteWidth = 1024px;
gutterWidth = 20px;
sidebarWidth = 300px;body {margin: 0 auto;width: siteWidth;
}
.content {float: left;width: siteWidth - (sidebarWidth+gutterWidth);
}
.sidebar {float: left;margin-left: gutterWidth;width: sidebarWidth;
}

其最终生成的css效果如下:

body {margin: 0 auto;width: 1024px;
}
.content {float: left;width: 704px;
}
.sidebar {float: left;margin-left: 20px;width: 300px;
}

12.高级语法

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

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

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

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

1.@for $var from <start> through <end>
2.@for $var from <start> to <end>。

其中$i表示变量,start表示起始值,end表示结束值,这两个的区别是关键字through表示包括end这个数,而to则不包括end这个数。

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

同时也支持while循环:

$i: 6;
@while $i > 0 {.item-#{$i} { width: 2em * $i; }$i: $i - 2;
}

最后,同时支持each命令,作用与for类似:

$animal-list: puma, sea-slug, egret, salamander;
@each $animal in $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');
}

以上就是sass,Less css与stylus的最显著的区别。

Sass、LESS 和 Stylus区别总结相关推荐

  1. scss、sass 和 css 的区别

    项目中,会经常使用诸如scss.sass的style样式,它们和css有什么区别呢? less大家应该都不陌生,同样的scss.sass一样,它们都可以称为:CSS预处理器语言. 简单来说,scss和 ...

  2. Sass、Scss、Less和Stylus区别总结

    Sass.Scss.Less.Stylus CSS 预处理器技术已经非常的成熟了,而且也涌现出了越来越多的 CSS 的预处理器框架.本文便总结下 Sass.Less CSS.Stylus这三个预处理器 ...

  3. CSS预处理器——Sass、LESS和Stylus区别及联系

    一.什么是CSS预处器 CSS预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为CSS增加了一些编程的特性,将CSS作为目标生成文件,然后开发者就只要使用这种语言进行编码工作.通俗的说 ...

  4. CSS3 之 less、sass、stylus区别

    CSS(Cascading Style Sheet)被译为级联样式表,做为一名前端从业人员来说,这个专业名词并不陌生,在行业中通常称之为"风格样式表(Style Sheet)",它 ...

  5. SASS 和 SCSS 的区别

    原文 Difference Between SASS and SCSS SASS(Syntactically Awesome Style Sheets)是一种由 Hampton Catlin 设计.C ...

  6. Sass和Scss的区别

    区别: Sass 和 SCSS 其实是同一种东西,我们平时都称之为 Sass,两者之间不同之处有以下两点: Sass是以".sass"后缀为扩展名,Scss是以scss后缀为扩展名 ...

  7. less和sass的定义和区别

    less是单独的一种文件,可以理解为css的升级版: sass是一个相对新的编程语言,为web前端开发而生,可以用它来定义一套新的语法规则和函数: 区别: ①   表现方式不同:less基于javas ...

  8. sass与scss的区别

    用了很久css预编译器,但是一直不太清楚到底用的sass还是scss,直到有天被问住了有点尴尬,找了个教程撸了遍==... 异同:简言之可以理解scss是sass的一个升级版本,完全兼容sass之前的 ...

  9. 关于sass(scss)、less、postcss、stylus等的用法与区别

    一. Sass/Scss.Less.stylus是什么? 它们都是css预处理器.css预处理器的概念:CSS预处理器用一种专门的编程语言,进行Web页面样式设计,然后再编译成正常的CSS文件,以供项 ...

最新文章

  1. 百度大脑发挥AI“头雁效应” 王海峰:在AI时代共同推动社会智能化升级
  2. PS Material 漫谈 六: Material Availability Check
  3. python学习手册笔记——22.模块代码编写基础
  4. EZ 2018 07 06 NOIP模拟赛
  5. 1110: 最近共同祖先(函数专题)
  6. spring boot生成Excel表格 导出/导入
  7. 【大数据公司研究】第三方大数据公司是如何赚钱的,以个推公司为例
  8. 来了,2020全球算力大会暨新基建矿业峰会,首批重磅嘉宾阵容出炉!
  9. 从内地或海外前往香港的步骤攻略(2023.2.更新)
  10. python halcon_HALCON高级篇:常用分类器及其特点
  11. 泰戈编程答案第一期(每周日更新)
  12. usb外接耳机声音过大解决方法
  13. python刷题 NOI题库 python题解 洛谷、牛客网、AcWing 刷题等
  14. linux中wq和wq 的区别,wq+linux+wq什么意思
  15. c++奇怪的1179链接错误
  16. 【ceph相关】pcie ssd相关问题处理
  17. 串行总线技术(一)-串行总线结构(以PCIe为例)
  18. 邮件客户端 web linux,分享|开始使用 Isotope 吧,一款开源的 Web 邮件客户端
  19. 解析 GetRerootedSIL
  20. 【一篇文章搞懂】什么是分布式锁?为什么要用分布式锁?看这篇文章准没错!

热门文章

  1. android手机解锁成功后的广播,Android动态注册锁屏、解锁、开屏系统广播
  2. STM32自学笔记ADC多通道扫描
  3. App设计者开发APP要注意的21个雷区(上)
  4. 同个网络计算机之间怎么共享,在局域网环境下的多台电脑之间如何实现文件共享需求呢?...
  5. MC/DC覆盖的计算总结
  6. 【软件工程】订货系统的UML类图
  7. 今日头条下拉框推广,出效果付费
  8. Numpy学习07-随机抽样
  9. 30段超实用CSS代码
  10. 养乐多深耕三线城市加码长、珠三角;欧康维视在港交所主板挂牌上市 | 美通企业日报...