stylusless和sass的区别

zcmos zcmos     2023-02-24     176

关键词:

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 */
h1
color: #0982c1
而 Stylus 支持的语法要更多样性一点,它默认使用 .styl 的文件扩展名,下面是 Stylus 支持的语法:

/* style.styl */
h1
color: #0982C1;


/* omit brackets */
h1
color: #0982C1;

/* omit colons and semi-colons */
h1
color #0982C1

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

h1
color #0982c1

h2
font-size: 1.2em

3.变量
1. sass:

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

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


2.less css :

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

Less css中变量都是用@开头的,其余与sass都是一样的,例如:
1
@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 maincolor
border 1px borderStyle mainColor
max-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 
h1
background color
border 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: 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)

其生成的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 - (@[email protected]);

.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结合多条件使用
1
代码如下:

$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循环有两种形式,分别为:

[email protected] $var from <start> through <end>
[email protected] $var from <start> to <end>。
1
2
其中$i表示变量,start表示起始值,end表示结束值,这两个的区别是关键字through表示包括end这个数,而to则不包括end这个数。

@for $i from 1 to 10
.border-#$i
border: #$ipx 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和scss有什么区别?

Sass官网上是这样描述Sass的:Sass是一门高于CSS的元语言,它能用来清晰地、结构化地描述文件样式,有着比普通CSS更加强大的功能。Sass能够提供更简洁、更优雅的语法,同时提供多种功能来创建可维护和管理的样式表。Sass前世... 查看详情

sass/scss和less的区别

一.Sass/Scss、Less是什么?Sass(SyntacticallyAwesomeStylesheets)是一种动态样式语言,Sass语法属于缩排语法,比css比多出好些功能(如变量、嵌套、运算,混入(Mixin)、继承、颜色处理,函数等),更容易阅读。Sass与Scss是什么关系?Sass的缩排语... 查看详情

sass/scss和less的区别

一.Sass/Scss、Less是什么?Sass(SyntacticallyAwesomeStylesheets)是一种动态样式语言,Sass语法属于缩排语法,比css比多出好些功能(如变量、嵌套、运算,混入(Mixin)、继承、颜色处理,函数等),更容易阅读。Sass与Scss是什么关系?Sass的缩排语... 查看详情

cssless和sass(scss)的区别

...Sass就是其中两种,下面我们就一起来看看它们到底有何区别。SASS和LESSSASS(英文全称:SyntacticallyAwesomeStylesheets)Sass诞生于2007年,使用Ruby编写,是一种对css的一种扩展提升,增加了规则、变量、混入、选择器、继承等等特性。... 查看详情

sass/scss和less的区别

感谢https://www.cnblogs.com/wangpenghui522/p/5467560.html 一.Sass/Scss、Less是什么?Sass(SyntacticallyAwesomeStylesheets)是一种动态样式语言,Sass语法属于缩排语法,比css比多出好些功能(如变量、嵌套、运算,混入(Mixin)、继承、颜色处理,函数等)... 查看详情

less和sass的区别,你知道么?

在介绍less和sass的区别之前,我们先来了解一下他们的定义:一、Less、Sass/Scss是什么?1、Less:是一种动态样式语言.对CSS赋予了动态语言的特性,如变量、继承、运算、函数。Less既可以在客户端上运行(支持IE6+,Webkit,Firefox),也可... 查看详情

css、scss、sass 和 less 有啥区别? [复制]

】css、scss、sass和less有啥区别?[复制]【英文标题】:What\'sthedifferencebetweencss,scss,sass,andless?[duplicate]css、scss、sass和less有什么区别?[复制]【发布时间】:2017-02-1208:03:17【问题描述】:我已经开发了大约两年的网站,但我从未使... 查看详情

sass/scss和less的区别(代码片段)

 一.Sass/Scss、Less是什么?Sass(SyntacticallyAwesomeStylesheets)是一种动态样式语言,Sass语法属于缩排语法,比css比多出好些功能(如变量、嵌套、运算,混入(Mixin)、继承、颜色处理,函数等),更容易阅读。Sass与Scss是什么关系?Sass的缩... 查看详情

sass 和 scss 有区别吗? [复制]

】sass和scss有区别吗?[复制]【英文标题】:Isthereadifferencebetweensassandscss?[duplicate]【发布时间】:2013-05-2807:38:29【问题描述】:我为网站的CSS开发了一些带有.scss脚本的ruby​​应用程序。但我遇到了一个使用.sass的新ruby​​应用... 查看详情

lsee和sass的区别

/Less中的注释,但这种不会被编译/* *这也是Less中的注释,但是会被编译 * *[Less中的变量] * *1、声明变量:@变量名:变量值; *  使用变量:@变量名 * * >>>Less中变量的类型: *&nb... 查看详情

十分钟看懂cssless和sass(scss)的区别

...Sass就是其中两种,下面我们就一起来看看它们到底有何区别。   背景 CSS(层叠样式表)是一门非程序式语言,入门学习使用非常直观方便,但是对于一些比较复杂或者重用性比较强的项目来说,因为CSS没有变量... 查看详情

sass和less的区别是什么?用哪个好

什么是Sass和Less?    Sass和Less都属于CSS预处理器,那什么是CSS预处理器呢?    CSS预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为CSS增加了一些编程的特性,将CSS作为目标... 查看详情

517,sytlus/sass/less的区别

均具有“变量”,“混合”,“嵌套”,“继承”,“颜色混合”五大基本特性scss和less语法较为严禁,less要求一定要使用大括号“”,scss和stylus可以通过缩进表示层次与嵌套关系scss没有全... 查看详情

saccless区别

sass和less主要区别在于实现方式:less是基于JavaScript的在客户端处理所以安装的时候用npm,sass是基于ruby所以在服务器处理。sass与less的区别:1、sass与less的安装:sass基于Ruby语言开发而成,因此安装sass前需要安... 查看详情

less以及sass两者啥区别

...可能,但终归是有可能的。关于变量在LESS和Sass中的唯一区别就是,LESS用@ 查看详情

作业:1scssless的区别用法gulpcmd命令

一、sass/scss和less的区别一.Sass/Scss、Less是什么? Sass(SyntacticallyAwesomeStylesheets)是一种动态样式语言,Sass语法属于缩排语法,比css比多出好些功能(如变量、嵌套、运算,混入(Mixin)、继承、颜色处理,函数等),更容易阅读。 Sa... 查看详情

less技术和sass技术定义用法及区别

 Less技术 定义:基于CSS的CSS扩展技术 特点:引入变量、混合、运算和函数。 作用:简化CSS代码。 1.定义变量。 形式:@变量名=值; 2.混合。 方式:可以用类选择器.; id选择器:#; 标签选... 查看详情

dart-sass与node-sass的区别以及使用dart-sass可能会出现的问题

...sassyarnremovenode-sass安装dart-sassyarnaddsass-Ddart-sass与node-sass的区别:node-sass是用node(调用cpp编写的libsass)来编译sassdart-sass是用dratVM来编译sassnode-sass是自动编译实时的,dart-sass需要保存后才会生效dart-sass性能更好(也是s 查看详情