首页
Javascript
Html
Css
Node.js
Electron
移动开发
小程序
工具类
服务端
浏览器相关
前端收藏
其他
关于

Sass、LESS 和 Stylus区别总结

2019年10月16日 转载自 csdn 阅读(70)

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

1.什么是 CSS 预处理器

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

2.基本语法区别:

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

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

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

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

  1. /* style.sass */
  2. h1
  3. color: #0982c1

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

  1. /* style.styl */
  2. h1 {
  3. color: #0982C1;
  4. }
  5. /* omit brackets */
  6. h1
  7. color: #0982C1;
  8. /* omit colons and semi-colons */
  9. h1
  10. color #0982C1

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

  1. h1 {
  2. color #0982c1
  3. }
  4. h2
  5. font-size: 1.2em

3.变量

1. sass:

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

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

2.less css :

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

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

3.stylus:

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

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

  1. body {
  2. color: #092873;
  3. border: 1px dotted #092873;
  4. max-width: 1024px;
  5. }

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

4.嵌套

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

  1. div {
  2. margin: 10px;
  3. }
  4. div nav {
  5. height: 25px;
  6. }
  7. div nav a {
  8. color: #0982C1;
  9. }
  10. div nav a:hover {
  11. text-decoration: underline;
  12. }

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

  1. //scss style //-----------------------------------
  2. nav {
  3. ul {
  4. margin: 0;
  5. padding: 0;
  6. }
  7. li {
  8. display: inline-block;
  9. }
  10. a {
  11. display: block;
  12. padding: 6px 12px;
  13. text-decoration: none;
  14. }
  15. }
  16. //css style //-----------------------------------
  17. nav ul {
  18. margin: 0;
  19. padding: 0;
  20. list-style: none;
  21. }
  22. nav li {
  23. display: inline-block;
  24. }
  25. nav a {
  26. display: block;
  27. padding: 6px 12px;
  28. text-decoration: none;
  29. }

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

5.运算符

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

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

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

6.颜色函数

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

1.sass的颜色处理函数:

  1. lighten($color, 10%);
  2. darken($color, 10%);
  3. saturate($color, 10%);
  4. desaturate($color, 10%);
  5. grayscale($color);
  6. complement($color);
  7. invert($color);
  8. mix($color1, $color2, 50%);

实例如下:

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

2.Less css颜色处理函数:

  1. lighten(@color, 10%);
  2. darken(@color, 10%);
  3. saturate(@color, 10%);
  4. desaturate(@color, 10%);
  5. spin(@color, 10);
  6. spin(@color, -10);
  7. mix(@color1, @color2);

示例如下:

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

3.Stylus颜色处理函数:

  1. lighten(color, 10%);
  2. darken(color, 10%);
  3. saturate(color, 10%);
  4. desaturate(color, 10%);

示例如下;

  1. color = #0982C1
  2. h1
  3. background color
  4. border 3px solid darken(color, 50%)

7.导入 (Import)

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

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

  1. //1.css
  2. /* file.{type} */
  3. body {
  4. background: #000;
  5. }

2.XXX:

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

最终生成的 CSS:

  1. @ import "1.css";
  2. body {
  3. background: #000;
  4. }
  5. p {
  6. background: #092873;
  7. }

8.继承

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

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

  1. .message {
  2. border: 1px solid #ccc;
  3. padding: 10px;
  4. color: #333;
  5. }
  6. .success {
  7. @extend .message;
  8. border-color: green;
  9. }
  10. .error {
  11. @extend .message;
  12. border-color: red;
  13. }
  14. .warning {
  15. @extend .message;
  16. border-color: yellow;
  17. }

2.Less css:

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

  1. .message {
  2. border: 1px solid #ccc;
  3. padding: 10px;
  4. color: #333;
  5. }
  6. .success {
  7. .message;
  8. border-color: green;
  9. }
  10. .error {
  11. .message;
  12. border-color: red;
  13. }
  14. .warning {
  15. .message;
  16. border-color: yellow;
  17. }

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

  1. .message, .success, .error, .warning {
  2. border: 1px solid #cccccc;
  3. padding: 10px;
  4. color: #333;
  5. }
  6. .success {
  7. border-color: green;
  8. }
  9. .error {
  10. border-color: red;
  11. }
  12. .warning {
  13. border-color: yellow;
  14. }

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

9.Mixins(混入)

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

1.Sass 的混入语法:

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

  1. @mixin error($borderWidth: 2px) {
  2. border: $borderWidth solid #F00;
  3. color: #F00;
  4. }
  5. .generic-error {
  6. padding: 20px;
  7. margin: 4px;
  8. @ include error(); //这里调用默认 border: 2px solid #F00;
  9. }
  10. .login-error {
  11. left: 12px;
  12. position: absolute;
  13. top: 20px;
  14. @ include error(5px); //这里调用 border:5px solid #F00;
  15. }

2.Less CSS 的混入语法:
less也支持带参数的混合以及有默认参数值的混合,如下面的例子所示:

  1. .error(@borderWidth: 2px) {
  2. border: @borderWidth solid #F00;
  3. color: #F00;
  4. }
  5. .generic-error {
  6. padding: 20px;
  7. margin: 4px;
  8. .error(); //这里调用默认 border: 2px solid #F00;
  9. }
  10. .login-error {
  11. left: 12px;
  12. position: absolute;
  13. top: 20px;
  14. .error(5px); //这里调用 border:5px solid #F00;
  15. }

3.Stylus 的混入语法:

  1. error(borderWidth= 2px) {
  2. border: borderWidth solid #F00;
  3. color: #F00;
  4. }
  5. .generic-error {
  6. padding: 20px;
  7. margin: 4px;
  8. error();
  9. }
  10. .login-error {
  11. left: 12px;
  12. position: absolute;
  13. top: 20px;
  14. error(5px);
  15. }

他们最终呈现的效果都如下:

  1. .generic-error {
  2. padding: 20px;
  3. margin: 4px;
  4. border: 2px solid #f00;
  5. color: #f00;
  6. }
  7. .login-error {
  8. left: 12px;
  9. position: absolute;
  10. top: 20px;
  11. border: 5px solid #f00;
  12. color: #f00;
  13. }

10.3D文本

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

1.sass:

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

2.Less CSS:

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

3.Stylus:

  1. text3d(color)
  2. color: color
  3. text-shadow: 1px 1px 0px darken(color, 5%),
  4. 2px 2px 0px darken(color, 10%),
  5. 3px 3px 0px darken(color, 15%),
  6. 4px 4px 0px darken(color, 20%),
  7. 4px 4px 2px #000
  8. span
  9. font-size: 32pt
  10. text3d(#0982c1)

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

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

11.列 (Columns)

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

  1. $siteWidth: 1024px;
  2. $gutterWidth: 20px;
  3. $sidebarWidth: 300px;
  4. body {
  5. margin: 0 auto;
  6. width: $siteWidth;
  7. }
  8. .content {
  9. float: left;
  10. width: $siteWidth - ($sidebarWidth+$gutterWidth);
  11. }
  12. .sidebar {
  13. float: left;
  14. margin-left: $gutterWidth;
  15. width: $sidebarWidth;
  16. }

2.Less CSS:

  1. @siteWidth: 1024px;
  2. @gutterWidth: 20px;
  3. @sidebarWidth: 300px;
  4. body {
  5. margin: 0 auto;
  6. width: @siteWidth;
  7. }
  8. .content {
  9. float: left;
  10. width: @siteWidth - (@sidebarWidth+@gutterWidth);
  11. }
  12. .sidebar {
  13. float: left;
  14. margin-left: @gutterWidth;
  15. width: @sidebarWidth;
  16. }

3.Stylus:

  1. siteWidth = 1024px;
  2. gutterWidth = 20px;
  3. sidebarWidth = 300px;
  4. body {
  5. margin: 0 auto;
  6. width: siteWidth;
  7. }
  8. .content {
  9. float: left;
  10. width: siteWidth - (sidebarWidth+gutterWidth);
  11. }
  12. .sidebar {
  13. float: left;
  14. margin-left: gutterWidth;
  15. width: sidebarWidth;
  16. }

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

  1. body {
  2. margin: 0 auto;
  3. width: 1024px;
  4. }
  5. .content {
  6. float: left;
  7. width: 704px;
  8. }
  9. .sidebar {
  10. float: left;
  11. margin-left: 20px;
  12. width: 300px;
  13. }

12.高级语法

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

  1. @if可一个条件单独使用,也可以和@else结合多条件使用

代码如下:

  1. $lte7: true;
  2. $type: monster;
  3. .ib{
  4. display:inline-block;
  5. @if $lte7 {
  6. *display:inline;
  7. *zoom:1;
  8. }
  9. }
  10. p {
  11. @if $type == ocean {
  12. color: blue;
  13. } @else if $type == matador {
  14. color: red;
  15. } @else if $type == monster {
  16. color: green;
  17. } @else {
  18. color: black;
  19. }
  20. }

其最终的css代码如下:

  1. .ib{
  2. display:inline-block;
  3. *display:inline;
  4. *zoom:1;
  5. }
  6. p {
  7. color: green;
  8. }

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

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

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

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

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

同时也支持while循环:

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

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

  1. $animal-list: puma, sea-slug, egret, salamander;
  2. @each $animal in $animal-list {
  3. .#{$animal}-icon {
  4. background-image: url('/images/#{$animal}.png');
  5. }
  6. }

其css最终效果如下:

  1. .puma-icon {
  2. background-image: url('/images/puma.png');
  3. }
  4. .sea-slug-icon {
  5. background-image: url('/images/sea-slug.png');
  6. }
  7. .egret-icon {
  8. background-image: url('/images/egret.png');
  9. }
  10. .salamander-icon {
  11. background-image: url('/images/salamander.png');
  12. }

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

© 本文著作权归原作者所有 来源:csdn 阅读原文

评论

  •  
  • Sass、LESS 和 Stylus区别总结

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

    发布:2019-10-16 阅读(70)

  • 使用 media query 进行 IE 的 CSS Hack

    通过 media query 进行 CSS 的 hack。在 IE 中它们可以识别出这些特殊的符号 \0,\, 以及 \9,然后结合 media query 可以更好进行样式的区分

    发布:2019-08-07 阅读(374)

  • Css Grid fr单位

    css fr 单位是一个自适应单位,fr单位被用于在一系列长度值中分配剩余空间,如果多个已指定了多个部分,则剩下的空间根据各自的数字按比例分配。

    发布:2019-02-28 阅读(768)

  • CSS Grid网格布局指南(学习)

    CSS网格布局是CSS中最强大的布局系统。它是一个二维系统,这意味着它可以处理列和行,不像flexbox主要是一维系统。CSS网格布局用于将页面分割成数个主要区域,或者用来定义组件内部元素间大小、位置和图层之间的关系。像表格一样,网格布局让我们能够按行或列来对齐元素。 但是,使用CSS网格可能还是比CSS表格更容易布局。 例如,网格容器的子元素可以自己定位,以便它们像CSS定位的元素一样,真正的有重叠和层次。

    发布:2019-02-28 阅读(675)

  • 什么是Sass,SCSS与它是什么关系?

    什么是Sass,SCSS与它是什么关系?

    发布:2019-02-26 阅读(720)

  • css3 自定义浏览器滚动条(scrollbar)

    通过-webkit-scrollbar自定义浏览器滚动条,支持webkit的浏览器可正常显示(如chrome,safari,QQ浏览器,360极速等)

    发布:2019-01-28 阅读(870)

  • CSS中伪类和伪元素总结

    css伪类和伪元素有什么区别?

    发布:2019-01-14 阅读(605)

  • 视窗单位vm,vh,vmin,vmax

    记录下响应式布局单位(视窗单位:viewport units)的应用,最近用electron开发桌面应用,用到vh,vw还是蛮方便的.

    发布:2019-01-09 阅读(422)

  • 妙法攻略:渐变虚框及边框滚动动画的纯CSS实现

    CSS3实现滚动边框,渐变边框

    发布:2018-12-07 来源:张鑫旭

  • CSS3 手册

    CSS3 是层叠样式表(Cascading Style Sheets)语言的最新版本,旨在扩展CSS2.1。它带来了许多期待已久的新特性, 例如圆角、阴影、gradients(渐变) 、transitions(过渡) 与 animations(动画) 。以及新的布局方式,如 multi-columns 、 flexible box 与 grid layouts。实验性特性以浏览器引擎为前缀(vendor-prefixed),应避免在生产环境中使用,或极其谨慎地使用,因为将来它们的语法和语义都有可能被更改。

    发布:2018-11-06 来源:mozilla

  • 探究 CSS 解析原理

    浏览器 CSS 模块负责 CSS 脚本解析,并为每个 Element 计算出样式。CSS 模块虽小,但是计算量大,设计不好往往成为浏览器性能的瓶颈。

    发布:2017-12-15 阅读(222)

  • [布局概念] 关于CSS-BFC深入理解

    BFC(Block formatting context)直译为&amp;quot;块级格式化上下文&amp;quot;。它**是一个独立的渲染区域**,只有**Block\-level box**参与(在下面有解释), 它规定了内部的Block\-level Box如何布局,并且与这个区域外部毫不相干。

    发布:2017-06-09 阅读(271)

  • 移动端retina屏1px细边框问题

    retina屏下(window.devicepixelratio>1),1px的边框会被渲染成2px,看起会比较粗,如何解决?

    发布:2017-02-15 阅读(758)

  • 隐藏input type=number元素,右侧的上下箭头

    通过CSS隐藏input='number'时,右侧的箭头

    发布:2015-08-21 阅读(1264)

  • 移动端 UC浏览器字体放大的问题

    在做移动端页面时,发现UC浏览器在文字居多的页面(如文章页面、关于我们页面),字体会自动放大。其他的浏览器都没有问题~~

    发布:2015-08-17 阅读(636)

  • 利用rgba和filter设置CSS背景颜色半透明且不影响子元素,兼容IE6-8

    css设置子元素半透明,兼容IE6-8

    发布:2013-05-28 阅读(689)

  • text-overflow:clip | ellipsis 单行截断文字

    利用CSS截断单行文字,溢出的显示"..."

    发布:2012-11-23 阅读(678)

  • 禁止<textarea>标签右下角拉动

    HTML标签textarea在大部分浏览器中只要指定行(rows)和列(cols)属性,就可以规定 textarea 的尺寸,大小就不会改变,不过更好的办法是使用 CSS 的 height 和 width 属性,但是Chrome,Safari和FireFox渲染的效果不同,可以拖动右下角图标改变大小

    发布:2012-11-14 阅读(651)

  • 去掉Chrome,Safari等浏览器input,select,textarea等form元素的高亮效果

    chrome、safari等现代浏览器,input,textarea,select等一些Form元素,会有一个默认的高亮样式

    发布:2012-11-13 阅读(676)

  • CSS设置超链接a:link,a:visited,a:hover,a:active的顺序

    CSS针对超链接4个状态的设置是有顺序的,顺序不对,a链接的各种状态可能不会生效

    发布:2012-10-23 阅读(706)

  • CSS常用hack技巧

    在当前的WEB前端页面制作中,鉴于市面上浏览器种类繁多(IE6-IE9、firefox、Chrome、Safari、Opera等等),各种浏览器对CSS的解析效果会有所不同(少数),所以要想让页面完全的兼容所有浏览器,就必须要用css hack。可能不同的开发人员,使用的hack方式不一样,但最终的目的都是希望各种浏览器渲染出同样的页面效果

    发布:2012-10-16 阅读(787)

  • 利用CSS制作尖角

    用两个◆制作尖角(引用腾讯微博中的做法)

    发布:2012-10-15 阅读(651)