sassless和stylus区别总结(代码片段)

kevins-yuan kevins-yuan     2023-02-02     765

关键词:

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属性是一样的,例如:

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

[email protected]for $var from <start> through <end>
[email protected]for $var from <start> to <end>。

其中$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‘); 









(转)预处器的对比——sassless和stylus

英文原文:http://net.tutsplus.com/tutorials/html-css-techniques/sass-vs-less-vs-stylus-a-preprocessor-shootout原文链接:http://www.w3cplus.com/css/sass-vs-less-vs-stylus-a-preprocessor-shootout.html介绍CSS预处理器是一种 查看详情

css预处理器(框架)初探:sassless和stylus

现在最为普遍的三款CSS预处理器框架,分别是Sass、LessCSS、Stylus。拿less来说,可以在页面上直接使用less文件,但要引用less.js进行解析;同时也可以直接将less输出为css文件。推荐使用后者。最常用的less编译输出css工具:与node.js... 查看详情

observablecollection和list的区别总结(代码片段)

一、继承的类和接口,还有它们的方法不同1)ObservableCollection比较简单,继承了Collection,INotifyCollectionChanged,INotifyPropertyChanged  Collection:为泛型集合提供基类。  INotifyCollectionChanged:将集合的动态更改通知给侦听器,例如,... 查看详情

java并发总结(代码片段)

文章目录线程和进程的区别线程的生命周期并发和并行的区别wait和sleep的区别yield和join的区别线程死锁守护线程与用户线程线程同步synchronized关键字理解上下文切换单例模式ReentrantLock二者的区别非堵塞同步生成者消费组问题Threa... 查看详情

scrollwidthclientwidthoffsetwidth的区别及总结(代码片段)

它们都是Element的属性,表示元素的宽度。Element.scrollWidth  内容+内边距+溢出尺寸-----不包括边框和外边距 ==实际内容Element.offsetWidth 元素的宽度(内容+内边距+边框+滚动条)==整体,整个控件Element.clientWidth  ... 查看详情

总结一下几个for循环常见用法和区别(代码片段)

1.for循环//有人喜欢使用一个临时变量把长度缓存起来,说是大数据时效果更好(我本人没有去验证)for(j=0,len=arr.length;j<len;j++)//执行代码分析可用功能break和continue2.forEach//遍历数组中的每一项,没有返回值,对原数组没有影响... 查看详情

熬夜总结的2022java面试题(代码片段)

...面向对象?值传递和引用传递?*==和equals的区别是什么?重载和重写的区别?抽象类和接口的区别*构造器Constructor是否可被override?java静态变量、代码块、和静态方法的执行顺序是什么?break,continue,return的区别... 查看详情

stylusless和sass的区别

...来越多的CSS的预处理器框架。本文便总结下Sass、LessCSS、Stylus这三个预处理器的区别和各自的基本语法。1.什么是CSS预处理器CSS预处理器是一种语言用来为CSS增加一些编程的的特性,无需考虑浏览器的兼容性问题,例如你可以在CS... 查看详情

项目问题解决(代码片段)

1.stylus在webstorm中出现红色波浪线但是不影响浏览器效果,也不报错<stylelang="stylus"scoped>articledisplayflexbackgroundlightblueheight0.64rem//此处数字处.leftfloatleft.centerflex1//此处数字处backgroundwhite.rightfloatright</style>1.style默认的css类似... 查看详情

docker学习总结(58)——dockerfile中,add和copy的区别?(代码片段)

...是在构建镜像的过程中完成的。COPY指令和ADD指令的唯一区别在于是否支持从远程URL获取资源。COPY指令只能从执行dockerbuild所在的主机上读取资源并复制到镜像中。而ADD指令还支持通过URL从远程服务器读取资源并复制到镜像中。... 查看详情

docker学习总结(58)——dockerfile中,add和copy的区别?(代码片段)

...是在构建镜像的过程中完成的。COPY指令和ADD指令的唯一区别在于是否支持从远程URL获取资源。COPY指令只能从执行dockerbuild所在的主机上读取资源并复制到镜像中。而ADD指令还支持通过URL从远程服务器读取资源并复制到镜像中。... 查看详情

sass和stylus1px解决方案(代码片段)

1.sass1@charset"utf-8";2/**3*@module背景与边框4*@description为元素添加边框(包括1px边框)5*@methodborder6*@version2.0.07*@paramString$border-width指定边框厚度(单位为px),默认值:1px,取值与`border-width`属性一致,不同方向代表边框位置<2.0.0>... 查看详情

java并发常见面试题总结(上)(代码片段)

...进程?何为进程?何为线程?请简要描述线程与进程的关系,区别及优缺点?图解进程和线程的关系程序计数器为什么是私有的?虚拟机栈和本地方法栈为什么是私有的?一句话简单了解堆和方法区并发与并行的区别同步和异步的区... 查看详情

总结软连接和硬连接区别,并用实例操作说明。(代码片段)

软链接  ln-s原文件目标文件  特征:1、相当于windows的快捷方式   2、符号链接,所以链接文件大小都很小   3、当运行软连接的时候,会根据链接指向找到真正的文件,然后执行4、所有链接文件的权限都是777,而真... 查看详情

c#知识点总结系列:4c#中monitor和lock以及区别(代码片段)

from:https://www.cnblogs.com/chengxingliang/p/3150731.html  Monitor对象  1.Monitor.Enter(object)方法是获取锁,Monitor.Exit(object)方法是释放锁,这就是Monitor最常用的两个方法,当然在使用过程中为了避免获取锁之后因为异常,致锁无法释放,... 查看详情

记录union和unionall一些总结(代码片段)

...是有一些怎么也不对。首先,需要搞明白Union和UnionAll的区别Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;UnionAll:对两个结果集进行并集操作,包括重复行,不进行排序;区别可以参照:Createtabl... 查看详情

c#知识点总结系列:3c#中delegate和event以及它们的区别(代码片段)

1.Monitor.Enter(object)方法是获取锁,Monitor.Exit(object)方法是释放锁,这就是Monitor最常用的两个方法,当然在使用过程中为了避免获取锁之后因为异常,致锁无法释放,所以需要在trycatch()之后的finally结构体中释放锁(Monitor.Exit())。 ... 查看详情

javase视频学习阶段性总结五(方法重写与方法重载的区别)(代码片段)

...在很多问题,这些概念很容易混淆,掌握重写和重载的区别对学会使用多态的方式编写程序 查看详情