一文讲述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 <list or map>。 其中$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;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/651853.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

优雅的管理你的docker容器【Docker Swarm篇】

如果docker容器较多时&#xff0c;可以使用docker-compose管理自己的容器组&#xff0c;但是随着容器增多&#xff0c;docker-compose也会变的复杂起来&#xff0c;如果使用k8s&#xff0c;又会比较重&#xff0c;因为k8s集群的最小运行内存为2GB&#xff0c;所以在这中间&…

【Spring Boot 3】【@Scheduled】动态新增定时任务

【Spring Boot 3】【@Scheduled】动态新增定时任务 背景介绍开发环境开发步骤及源码工程目录结构总结背景 软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技…

深度学习 | 基于 CPU 的 tensorflow + keras + python 版本对照及环境安装

Hi&#xff0c;大家好&#xff0c;我是源于花海。要让一个基于 CPU 的 tensorflow 和 keras 开发的深度学习模型正确运行起来&#xff0c;配置环境是个重要的问题&#xff0c;本文介绍了 tensorflow 和 keras 和对应的 python 版本以及安装环境的部分流程。 目录 一、tensorfl…

Redis核心技术与实战【学习笔记】 - 3.Redis服务高可靠

1.数据同步&#xff1a;主从库如何实现数据一致&#xff1f; 前面我们学习了 AOF 和 RDB&#xff0c;如果 Redis 发生了宕机&#xff0c;它们可以分别通过回放日志和重新读入 RDB 文件的方式恢复数据&#xff0c;从而保证尽量较少丢失数据&#xff0c;提升可靠性。 不过&…

B.修改数列

给定一个长度为 n 的正整数数列 a1,a2,…,an。 你可以对其中任意个&#xff08;可以是 0 个&#xff09;元素进行修改。 但是&#xff0c;每个元素最多只能修改一次&#xff0c;每次修改&#xff1a;要么令其加 1&#xff0c;要么令其减 1。 请问&#xff0c;至少需要修改多少个…

RTP工具改进(五)--使用qt

前篇 第四篇 RTP工具改进(四) - rtmp协议推送 前面使用的工具一直为mfc&#xff0c;今天将使用qt 来做界面&#xff0c;使用qt 来进行程序和协议的编写&#xff0c;qt部分目前还不包括rtp ps流和rtmp&#xff0c;暂时只有rtp 直接传输&#xff0c;关于rtmp协议和ps流协议&…

ubuntu和树莓派下vim插件管理

目录 管理方式选择vim手动方式管理插件延迟加载加载插件帮助文档 make管理vim插件1.安装make和git2.获取vim配置仓库3.准备工作4.安装相关软件5.安装并升级vim插件6.安装vim配置相关文件7.vim恢复到初始状态 管理方式选择 插件管理器vim-plug,Vundle等都依靠github,在国内由于…

在 VUE 项目中,使用 Axios 请求数据时,提示跨域,该怎么解决?

在 VUE 项目开发时&#xff0c;遇到个问题&#xff0c;正常设置使用 Axios 库请求数据时&#xff0c;报错提示跨域问题。 那在生产坏境下&#xff0c;该去怎么解决呢&#xff1f; 其可以通过以下几种方式去尝试解决&#xff1a; 1、设置允许跨域请求的响应头 1.1 在响应头中…

STM32实现软件IIC协议操作OLED显示屏(2)

时间记录&#xff1a;2024/1/27 一、OLED相关介绍 &#xff08;1&#xff09;显示分辨率128*64点阵 &#xff08;2&#xff09;IIC作为从机的地址0x78 &#xff08;3&#xff09;操作步骤&#xff1a;主机先发送IIC起始信号S&#xff0c;然后发送OLED的地址0x78&#xff0c;然…

机器学习的数据库积累........

https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/tf1_detection_zoo.md ​​​​​​​ 另一个database:&#xff08;网址:Object Detection Made Easy with TensorFlow Hub: Tutorial&#xff09; Object Detection Made Easy with Ten…

VR拍摄+制作

1.VR制作需要的图片宽高是2:1&#xff0c;需要360✖️180的图片&#xff0c;拍摄设备主要有两种&#xff1a; 1&#xff09;通过鱼眼相机拍摄&#xff0c;拍摄一组图片&#xff0c;然后通过PTGui来合成(拍摄复杂) 2&#xff09;全景相机&#xff0c;一键拍摄直接就能合成需要的…

【动态规划】【逆向思考】【C++算法】960. 删列造序 III

作者推荐 【动态规划】【map】【C算法】1289. 下降路径最小和 II 本文涉及知识点 动态规划汇总 LeetCode960. 删列造序 III 给定由 n 个小写字母字符串组成的数组 strs &#xff0c;其中每个字符串长度相等。 选取一个删除索引序列&#xff0c;对于 strs 中的每个字符串&a…

群晖nas 中的 VideoStation 关于豆瓣刮刮和TheMovieDb无法链接问题

网上各种教学文档很多&#xff0c;但是都有各种的坑&#xff0c;这偏文章仅对坑进行修正&#xff0c;具体可以参考其他文章&#xff0c;不同点以此文章为准。 第一部分&#xff0c;豆瓣刮刮 是 VideoStation的最佳搭配&#xff0c;汉字匹配&#xff0c;速度肯定是TheMovieDb无…

贾玲新片刚刚发出紧急声明,是什么情况。

♥ 为方便您进行讨论和分享&#xff0c;同时也为能带给您不一样的参与感。请您在阅读本文之前&#xff0c;点击一下“关注”&#xff0c;非常感谢您的支持&#xff01; 文 |猴哥聊娱乐 编 辑|徐 婷 校 对|侯欢庭 1月22日&#xff0c;一则“多位明星参演的电影涉影视投资诈骗…

【Java 设计模式】行为型之访问者模式

文章目录 1. 定义2. 应用场景3. 代码实现结语 访问者模式&#xff08;Visitor Pattern&#xff09;是一种行为型设计模式&#xff0c;用于在不改变被访问元素的类的前提下定义对这些元素的新操作。访问者模式将数据结构与作用于结构上的操作解耦&#xff0c;使得操作集合可以灵…

[晓理紫]每日论文分享(有中文摘要,源码或项目地址)--强化学习、模仿学习、机器人、开放词汇

专属领域论文订阅 关注{晓理紫|小李子}&#xff0c;每日更新论文&#xff0c;如感兴趣&#xff0c;请转发给有需要的同学&#xff0c;谢谢支持 如果你感觉对你有所帮助&#xff0c;请关注我&#xff0c;每日准时为你推送最新论文。 分类: 大语言模型LLM视觉模型VLM扩散模型视觉…

STM32 freertos 使用软件模拟串口uart

如题&#xff0c;为什么要这样做&#xff1f; 最近做的一个项目上使用了74HC595作为指示灯板使用&#xff1b; 这个灯板与驱动板是通过排线连接&#xff0c;排线约25cm长&#xff1b; 在实验室测试一切正常&#xff0c;发到客户手上使用就出现了某个LED跳动情况&#xff1b;…

假期刷题打卡--Day16

一、码题集正常刷题 1、MT1159 指定集合 某数组含有N个元素&#xff0c;输出那些数字来自集合{4,5,6}的元素&#xff0c;按原序。没有就输出-1。 格式 输入格式&#xff1a; 第一行输入数组长度N&#xff0c;第二行输入数组元素&#xff0c;整型&#xff0c;空格分隔。 输…

GitHub 一周热点汇总第7期(2024/01/21-01/27)

GitHub一周热点汇总第7期 (2024/01/21-01/27) &#xff0c;梳理每周热门的GitHub项目&#xff0c;离春节越来越近了&#xff0c;不知道大家都买好回家的票没有&#xff0c;希望大家都能顺利买到票&#xff0c;一起来看看这周的项目吧。 #1 rustdesk 项目名称&#xff1a;rust…

解决Linux部署报错No main manifest attribute, in XXX.jar

这是我近期遇到的一个问题&#xff0c;报错原因就是没找到主类&#xff0c;首先你在你本地运行&#xff0c;本地运行ok的话&#xff0c;解压生成的jar包&#xff0c;里面有个META-INF文件&#xff0c;打开MANIFEST.MF文件&#xff0c;该文件是一个清单文件。该文件包含有关JAR文…