一文讲述SASS简介和使用方法

一、什么是Sass

Sass (Syntactically Awesome StyleSheets)是css的一个扩展开发工具,它允许你使用变量、条件语句等,使开发更简单可维护。这里是官方文档

二、基本语法

1)变量

sass的变量名必须是一个$符号开头,后面紧跟变量名。

//sass 样式
$red: #f00;
div {
   color: $red;   
}
// 编译为css后
div {
    color:#f00;   
}

***特殊变量:*如果变量嵌套在字符串中,则需要写在 #{} 符号里面,如:

$top: top;
div {
    margin-#{$top}: 10px;       /* margin-top: 10px; */
}

**默认变量:**仅需在值后面加入 !default即可, 默认变量一般用来设置默认值,当该变量出现另外一个值时,无论定义先后,都会使用另外一个值,覆盖默认值

$color: red;
$color: blue !default;
div {
    color: $color;    /* color:red; */
}

**多值变量:**多值变量分为list类型和map类型,list有点像js对象中的数组,map类型像js中的对象

**list :**可通过空格,逗号或小括号分割多个值,使用 nth($变量名, $索引)取值

|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 | //一维数据 $px: 5px 10px 20px 30px; //二维数据,相当于js中的二维数组 $px: 5px 10px, 20px 30px; $px: (5px 10px) (20px 30px); // 例子 $px: 10px 20px; div { ``margin:nth($px, 1) 0 0 nth($px, 2); ``/* margin:10px 0 0 20px; */ } |

**map:**数据以key和value组成,格式:map: (key1: value1, key2: value2); 通过map-get(map, $key);

复制代码
$headings: (h1: 2em, h2: 1.5em, h3: 1.2em);
@each $header, $size in $headings {
  #{$header} {
    font-size: $size;
  }
}

2)计算功能

sass允许使用算式。

|-----------|--------------------------------------------------------------------------------------------|
| 1 2 3 4 5 | div { ``padding: 2px * 4px; ``margin: (10px / 2); ``font-size: 12px + 4px; } |

3)嵌套

标签嵌套

|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | // sass 样式 div { ``color: #333; ``a { ``font-size:14px; ``&:hover { ``text-decoration:underline; ``} ``} } // 编译后css div { ``color: #333; } div a { ``font-size:14px; } div a:hover { ``text-decoration:underline; } |

属性嵌套:

|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | //sass 样式 .fakeshadow { ``border: { ``style: solid; ``left: { ``width: 4px; ``color: #888; ``} ``right: { ``width: 2px; ``color: #ccc; ``} ``} } //css 编译后样式 .fakeshadow { ``border-style: solid; ``border-left-width: 4px; ``border-left-color: #888; ``border-right-width: 2px; ``border-right-color: #ccc; } |

4)注释

sass有两种注释风格

标准css注释: /* 注释 */, 会保留到编译后的文件中,压缩则删除

单行注释: // 注释

在标准注释 /*后面加入一个感叹号,表示重要注释,压缩模式也会保留注释,用于版权声明等。

|---|---------------|
| 1 | /*! 重要注释 */ |

5)继承

sass 中,选择器继承可以让选择器继承另一个选择器的所有样式

|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | // sass样式 h1 { ``font-size:20px; } div { ``@extend h1; ``color:red; } // css编译后样式 h1 { ``font-size:20px; } div { ``font-size:20px; ``color:red; } |

使用占位符选择器 %

从sass3.2.0后,就可以定义占位选择器%,这个的优势在于,不调用不会有多余的css文件

|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | // sass样式 %h1 { ``font-size:20px; } div { ``@extend %h1; ``color:red; } // css编译后样式 div { ``font-size:20px; ``color:red; } |

6)混合(mixin)

sass中使用@mixin声明混合,可以传递参数,参数名义$符号开始,多个参数以逗号分开,如果参数有多组值,那么在变量后面加三个点表示,如: $var...

|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 | //sass 样式 @mixin opacity($opacity:50) { ``opacity: $opacity / 100; ``filter: alpha(opacity=$opacity); } .opacity{ ``@include opacity; ``//参数使用默认值 50/100 = 0.5 } .opacity-80{ ``@include opacity(80); ``//传递参数 80/100 = 0.8 } // css编译后样式 .opacity{ ``opacity: 0.5; ``filter: alpha(opacity=50); } // --------------------- // 多参数 @mixin center($width, $height) { ``position: absolute; ``left:50%; ``top:50%; ``width:$width; ``height:$height; ``margin:(-$height / 2) 0 0 (-$width / 2); } div { ``@include center(200px, 100px); } // css编译后样式 div { ``position: absolute; ``left:50%; ``top:50%; ``width:200px; ``height:100px; ``margin:-50px 0 0 -100px; } // ------------------- //多组值 @mixin box-shadow($shadow...) { ``-webkit-box-shadow: $shadow; ``box-shadow: $shadow; } div { ``@include box-shadow(0 1px 0 rgba(0,0,0,.4), 0 -1px 1px rgba(0,0,0,.4)); } // css编译后样式 div { ``-webkit-box-shadow: 0 1px 0 rgba(0,0,0,.4), 0 -1px 1px rgba(0,0,0,.4); ``box-shadow: 0 1px 0 rgba(0,0,0,.4), 0 -1px 1px rgba(0,0,0,.4); } |

**@content:**在sass3.2.0中引入, 可以用来解决css3中 @meidia 或者 @keyframes 带来的问题。它可以使@mixin接受一整块样式,接收的样式从@content开始

|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | //sass 样式 @mixin max-screen($res){ ``@media only screen and ( max-width: $res ) ``{ ``@content; ``} } @include max-screen(480px) { ``body { color: red } } //css 编译后样式 @media only screen and (max-width: 480px) { ``body { color: red } } |

使用@content解决**@keyframes关键帧的浏览器前缀问题**

|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | // 初始化变量 $browser: ``null``; // 设置关键帧 @mixin keyframes($name) { ``@-webkit-keyframes #{$name} { ``$browser: ``'-webkit-'``; @content; ``} ``@-moz-keyframes #{$name} { ``$browser: ``'-moz-'``; @content; ``} ``@-o-keyframes #{$name} { ``$browser: ``'-o-'``; @content; ``} ``@keyframes #{$name} { ``$browser: ``''``; @content; ``} } // 引入 @include keyframes(scale) { ``100% { ``#{$browser}transform: scale(0.8); ``} } // css编译后 @-webkit-keyframes scale { ``-webkit-transform: scale(0.8); } @-moz-keyframes scale { ``-moz-transform: scale(0.8); } @-o-keyframes scale { ``-o-transform: scale(0.8); } @keyframes scale { ``transform: scale(0.8); } |

7)颜色函数

sass提供了一些内置的颜色函数

|---------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 | lighten(#cc3, 10%)   ``// #d6d65c darken(#cc3, 10%)    ``// #a3a329 grayscale(#cc3)     ``// #808080 complement(#cc3)    ``// #33c |

8 )引入外部文件

使用 @import 命令引入外部文件, 引入后,可使用外部文件中的变量等。

|---|-----------------------------|
| 1 | @import ``"_base.scss"``; |

三、高级用法

1)函数 function

sass允许用户编写自己的函数,以@function开始

|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 | $fontSize: 10px; @function pxTorem($px) { ``@``return $px / $fontSize * 1rem; } div { ``font-size: pxTorem(16px); } // css编译后样式 div { ``font-size: 1.6rem; } |

2)if条件语句

@if语句可以用来判断

|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | // sass样式 $type: monster; div { ``@``if $type == ocean { ``color: blue; ``} @``else if $type == matador { ``color: red; ``} @``else if $type == monster { ``color: green; ``} @``else { ``color: black; ``} } // css编译后样式 div { ``color: green; } |

**三目判断:**语法为 if($condition, $if_true, $if_false)。 三个参数分别表示: 条件,条件为真的值,条件为假的值

复制代码
if(true, 1px, 2px) => 1px
if(false, 1px, 2px) => 2px

3)循环语句

for循环有两种形式,分别为:@for $var from <start> through <end> 和 @for $var from <start> to <end>。 $var 表示变量,start表示开始值,end表示结束值,两种形式的区别在于 through 包括 end 的值,to 不包括 end 值。

|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | // sass样式 @``for $i ``from 1 to 4 { ``.item-#{$i} {width: 2em * $i;} } // css编译后样式 .item-1 { ``width: 2em; } .item-2 { ``width: 4em; } .item-3 { ``width: 6em; } |

while循环

|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | // sass样式 $i: 2; @``while $i > 0 { ``.item-#{$i} {width: 2em * $i;} ``$i: $i - 1; } // css编译后样式 .item-2 { ``width: 4em; } .item-1 { ``width: 2em; } |

@each循环:语法为@each var in \。 其中var表示变量,而list和map表示数据类型,sass3.3.0新加入多字段循环和map数据循环

单字段list数据循环

|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | //sass 样式 $animal-list: puma, sea-slug, egret; @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'``); } |

多字段list数据循环

|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | //sass 样式 $animal-data: (puma, black, ``default``),(sea-slug, blue, pointer); @each $animal, $color, $cursor ``in $animal-data { ``.#{$animal}-icon { ``background-image: url(``'/images/#{$animal}.png'``); ``border: 2px solid $color; ``cursor: $cursor; ``} } //css 编译后样式 .puma-icon { ``background-image: url(``'/images/puma.png'``); ``border: 2px solid black; ``cursor: ``default``; } .sea-slug-icon { ``background-image: url(``'/images/sea-slug.png'``); ``border: 2px solid blue; ``cursor: pointer; } |

多字段map数据循环

|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | //sass 样式 $headings: (h1: 2em, h2: 1.5em, h3: 1.2em); @each $header, $size ``in $headings { ``#{$header} { ``font-size: $size; ``} } //css 编译后样式 h1 { ``font-size: 2em; } h2 { ``font-size: 1.5em; } h3 { ``font-size: 1.2em; } |

相关推荐
Pluto_ssy6 天前
Sass基础知识以及常用知识整理
前端·css·sass
Bl_a_ck7 天前
【CSS进阶】常见的页面自适应的方法
前端·css·less·css3·sass·html5·scss
旧人239 天前
微信小程序配置3 配置sass
微信小程序·小程序·sass
太阳与星辰9 天前
vue3实战-----集成sass
前端·typescript·sass·vue3实战
khatung9 天前
Sass更新:@import——>@use
开发语言·前端·javascript·css·vscode·sass
i7i8i9com24 天前
node-sass已经废弃了,需要替换成以下方式
前端·css·sass
m0_748254881 个月前
项目升级Sass版本或升级Element Plus版本遇到的问题
前端·rust·sass
樊南1 个月前
【esp32-uniapp】uniapp小程序篇02——引入组件库
小程序·uview·sass·scss·wechat·uiewplus·colorui
CaraYQ1 个月前
【sass+css变量实现换肤】
前端·css·sass
web前端神器1 个月前
记录node-sass无法安装的问题
前端·css·sass