如何使用SASS

1.背景介绍

1.1什么是Sass

Sass 是一款强化 CSS 的辅助工具,是预编译器。它在 CSS 语法的基础上增加了变量、嵌套、混合、导入等高级功能。

1.2诞生背景

CSS不是一个完美的语言。CSS简单易学,却也能迅速制造严重的混淆,尤其是在工程浩大的项目中。这就是 Sass 出现的契机,作为一种元语言,通过提供额外的功能和工具可以改善 CSS 的语法。同时,保留了 CSS 的原有特性。Sass 存在的关键不是将 CSS 变成一种全功能编程语言,它只是想修复缺陷。Sass 只在 CSS 的基础上添加了几个额外功能。

 

2.知识剖析

常用的Sass功能介绍

2.1 SassScript

在 CSS 属性的基础上 Sass 提供了一些名为 SassScript 的新功能。 SassScript 可作用于任何属性,允许属性使用变量、算数运算等额外功能。

2.1.1 变量 $

变量以美元符号$开头,赋值方法与 CSS 属性的写法一样

示例:

 

 

 

首先声明变量,为$blue赋值#5fc0cd,然后在background-color中引用变量,这样背景颜色就变成变量声明的颜色了。

全局变量,局部变量

变量支持块级作用域,嵌套规则内定义的变量只能在嵌套规则内使用(局部变量),不在嵌套规则内定义的变量则可在任何地方使用(全局变量)。将局部变量转换为全局变量可以添加 !global 声明。

示例:

全局变量:任何地方都可使用

 

 

 

局部变量:只能在嵌套规则内使用

 

 

 

注意:当全局变量遇上局部变量,局部变量覆盖全局变量

全局变量中的颜色为蓝色,局部变量中的颜色为黑色,黑色覆盖蓝色,最后的背景颜色呈现为黑色

 

2.1.2  数字运算

SassScript 支持数字的加减乘除、取整等运算 (+, -, *, /, %)

加法 +

 

 

 乘法 *

 

 

注意乘的数不能带单位

 除法 /

/ 在 CSS 中有分隔数字的用途,SassScript作为 CSS 语言的拓展也支持这个功能,同时也赋予了 / 除法运算的功能。

分隔数字:

 

 除法运算:

以下三种情况 / 将被视为除法运算符号:

(1)如果值,或值的一部分,是变量或者函数的返回值

(2)如果值被圆括号包裹

(3)如果值是算数表达式的一部分

 

 

2.2  嵌套

2.2.1  嵌套规则

Sass 允许将一套 CSS 样式嵌套进另一套样式中,内层的样式将它外层的选择器作为父选择器。它可以避免重复书写父选择器,使结构更加清晰明了,样式的可读性更高。

 

2.2.2  父选择器 &

嵌套应用于 :hover 的伪类时则不能简单地用嵌套了,这时候就需要使用父选择器&。父选择器 & 可以简单地理解为用 & 来表示父标签。

 

 

2.2.3  属性嵌套

有些 CSS 属性遵循相同的命名空间,比如background-color, background-image, background-size 都以 background 作为属性的命名空间。为了便于管理这样的属性,同时也为了避免了重复输入,Sass 允许将属性嵌套在命名空间中。

 

 

 

 

2.3  混合器

@mixin 混合器可以包含选择器和选择器中的属性,通过 @include 来传参,这样就可以非常方便的复用需要常用的样式了。

 

 

 

 

Flex垂直居中的调用

 

2.4 选择器继承

选择器继承是说一个选择器可以继承另一个选择器定义的所有样式。这个通过@extend语法实现

如果页面的header和footer的样式有共同之处,便可以在footer 使用 @extend来继承 header 的样式,免去重复书写。

 

 

 

 

 

 

3.常见问题

有些观点认为不要使用选择器嵌套比较好,其中原因有:

1.增加编译难度,编译生成的css文件父类过多

2.使得最终代码难以阅读,选择器越具体会使得声明语句越冗长

3.混淆选择器路径和探索下一级选择器的错误率很高

 

4.解决方案

我觉得过量使用选择器嵌套确实是不太好的,但是只要使用合理在结构或是代码易读性上都还是有很大帮助的。

使用一致的类命名空间来命名我觉得是个不错的解决办法,一致的类命名既使代码易读,也不会混淆选择器路径。

比如,使用myapp-Header-link 来当做一个类名,组成它的三个部分都有着特定的功能:

1.myapp 首先用来将我们的应用和其他可能运行在同一个 DOM 上的应用隔离开来

2.Header 用来将组件和应用里其他的组件隔离开来

3.link 用来为局部样式效果保存一个局部名称

这样第一个标签类名可以写成myapp,myapp下的头部组件则可以写成myapp-Header,Header下的链接元素则可以写成myapp-Header-link。当使用选择器嵌套的时候,配合使用父选择器&,这样各个部分的结构就很清晰明了,不会混淆。

 

 

5.编码实战 

 

6.扩展思考

Less与Sass的差异

1.编译环境不同,Less是基于JavaScript运行,所以Less是在客户端处理。Sass是基于Ruby的,是在服务器端处理的。

2.变量符不一样,Less是@,而Scss是$,而且变量的作用域也不一样。

3.输出设置,Less没有输出设置,Sass提供4中输出选项:nested, compact, compressed 和 expanded。

4.Sass支持条件语句,可以使用if{}else{},for{}循环等等。而Less不支持。

5.Sass和Less的工具库不同,Sass有工具库Compass, Less有UI组件 Bootstrap

  

7.参考文献

Sass中文网

https://www.sass.hk/

Sass中文网2

https://www.sasscss.com/

一个健壮且可扩展的 CSS 架构所需的8个简单规则

https://llp0574.github.io/2016/11/17/css-architecture/#3-use-consistent-class-namespacing

Less与Sass 的区别

http://www.cnblogs.com/wangpenghui522/p/5467560.html

posted @ 2020-04-28 14:44  努力~努力再努力~  阅读(421)  评论(0编辑  收藏  举报