2021-09-18 sass

SASS

SASS官网

世界上最成熟、最稳定、最强大的专业级CSS扩展语言!

sass 是一个 css 的预编译工具

也就是能够 更优雅 的书写 css

sass 写出来的东西 浏览器不认识

依旧要转换成 css 在浏览器中运行

这个时候就需要一个工具来帮我们做

安装 sass 环境

以前的 sass 需要依赖一个 ruby 的环境

现在的 sass 需要依赖一个 python 的环境

但是我们的 node 强大了以后,我们只需要依赖 node 环境也可以

需要我们使用 npm 安装一个全局的 sass 环境就可以了

# 安装全局 sass 环境

$ npminstall sass-g

编译 sass

有了全局的 sass 环境以后

我们就可以对 sass 的文件进行编译了

sass 的文件后缀有两种,一种是 .sass 一种是 .scss

他们两个的区别就是有没有 {} 和 ;

.scss 文件

h1{

width:100px;

height:200px;

}

.sass 文件

h1

    width: 100px

    height: 200px

我们比较常用的还是 .scss 文件

因为 .sass 我们写不习惯,当然,如果你能写习惯也比较好用

我们先不管里面的内容是什么,至少这个 .scss 或者 .sass 文件浏览器就不认识

我们要用指令把 这两种 文件变成 css 文件

# 把 index.scss 编译,输出成 index.css

$ sassindex.scss index.css

这样我们就能得到一个 css 文件,在页面里面引入一个 css 文件就可以了

实时编译

我们刚才的编译方式只能编译一次

当你修改了文件以后要从新执行一遍指令才可以

实时编译就是随着你文件的修改,自动从新编译成 css 文件

也是使用指令来完成

# 实时监控 index.scss 文件,只要发生修改就自动编译,并放在 index.css 文件里面

$ sass--watchindex.scss:index.css

然后你只要修改 index.scss 文件的内容,index.css 文件中的内容会自动更新

实时监控目录

之前的实时监控只能监控一个文件

但是我们有可能要写很多的文件

所以我们要准备一个文件夹,里面放的全部都是 sass 文件

实时的把里面的每一个文件都编译到 css 文件夹里面

依旧是使用指令的形式来完成

# 实时监控 sass 这个目录,只要有变化,就会实时响应在 css 文件夹下

$ sass--watchsass:css

这样,只要你修改 sass 文件夹下的内容,就会实时的相应在 css 文件夹中

你新添加一个文件也会实时响应

但是你删除一个文件,css 文件夹中不会自动删除,需要我们自己手动删除

sass 语法

我们能编译 sass 文件了,接下来我们就该学习一下 sass 的语法了

为什么他这么强大,这么好用,都是靠强大的语法

.sass 和 .scss 文件的语法是一样的,只不过区别就是 {} 和 ;

变量

定义一个变量,在后面的代码中使用

使用 $ 来定义变量

// 定义一个 $c 作为变量,值是 红色

$c:red;

h1{

// 在使用 $c 这个变量

color:$c;

}

上面定义的变量全局都可以使用

我们也可以在规则块内定义私有变量

h1{

// 这个 $w 变量只能在 h1 这个规则块中使用

$w:100px;

width:$w;

}

嵌套

sass 里面我们最常用到的就是嵌套了

而且相当的好用

h1{

width:100px;


div{

width:200px;

   }

}

// 编译结果

h1{

width:100px;

}

h1div{

width:200px;

}

这个就是嵌套,理论上可以无限嵌套下去

ul{

width:100px;


li{

width:90px;


div{

width:80px;


p{

width:70px;


span: {

color:red;

               }

           }

       }

   }

}

嵌套中的 &

在嵌套中还有一个标识符是 & 我们可以使用

先来看一个例子

div{

width:100px;

height:100px;


:hover{

width:200px;

   }

}

// 我想的是 div 被鼠标悬停的时候 width 变成 200

// 但是编译结果却是

div{

width:100px;

height:100px;

}

div:hover{

  width:200px;

}

和预想的结果不一样了

这个时候就要用到 & 来连接了

div{

width:100px;

height:100px;

&:hover{

width:200px;

   }

}

// 编译结果

div{

width:100px;

height:100px;

}

div:hover{

  width:200px;

}

这个时候就和我需要的一样了

群组嵌套

群组嵌套就是多个标签同时嵌套

div{

width:100px;


.box1,.box2,.box3{

color:red;

   }

}

// 编译结果

div{

  width:100px;

}

div.box1,div.box2,div.box3{

  color:red;

}

还有一种就是多个标签同时嵌套一个标签

h1,h2,h3{

width:100px;

.box{

color:red;

   }

}

// 编译结果

h1,h2,h3{

  width:100px;

}

h1.box,h2.box,h3.box{

  color:red;

}

嵌套属性

在 scss 里面还有一种特殊的嵌套

叫做 属性嵌套

和选择器嵌套不一样,是写属性的时候使用的

div{

border: {

style:solid;

width:10px;

color:pink;

   }

}

// 编译结果

div{

border-style:solid;

border-width:10px;

border-color:pink;

}

这个属性嵌套还可以有一些特殊使用

div{

border:1pxsolid#333{

bottom:none;

   }

}

// 编译结果

div{

border:1pxsolid#333;

border-bottom:none;

}

混入

也叫 混合器

其实就是定义一个 “函数” 在 scss 文件中使用

// 定义一个混合器使用  @mixin 关键字

@mixinradius{

-webkit-border-radius:10px;

-moz-border-radius:10px;

-ms-border-radius:10px;

-o-border-radius:10px;

border-radius:10px;

}

上面是定义好的一个混合器

他是不会被编译的,只有当你使用了他以后,才会被编译

// 使用混合器使用 @include 关键字

div{

width:100px;

height:100px;

@includeradius;

}

这个就是把刚才定义的混合器拿过来使用

编译结果

div{

width:100px;

height:100px;

-webkit-border-radius:10px;

-moz-border-radius:10px;

-ms-border-radius:10px;

-o-border-radius:10px;

border-radius:10px;

}

混合器传参

我们既然说了,混合器就像一个 “函数” 一样,那么就一定可以像 “函数” 一样传递参数

和 “函数” 的使用方式一样,在定时的时候是 “形参”,在调用的时候是 “实参”

// 定义混合器

@mixinmy_transition($pro,$dur,$delay,$tim) {

-webkit-transition:$pro$dur$delay$tim;

-moz-transition:$pro$dur$delay$tim;

-ms-transition:$pro$dur$delay$tim;

-o-transition:$pro$dur$delay$tim;

transition:$pro$dur$delay$tim;

}

使用这个混合器的时候传递 “实参”

div{

width:100px;

height:100px;

@includemy_transition(all,1s,0s,linear);

}

编译结果

div{

width:100px;

height:100px;

-webkit-transition:all1s0slinear;

-moz-transition:all1s0slinear;

-ms-transition:all1s0slinear;

-o-transition:all1s0slinear;

transition:all1s0slinear;

}

写了多少个 “形参”,那么调用的时候就要传递多少个 “实参”

不然会报错的

参数默认值

我们在定义混合器的时候,也可以给一些参数写一些默认值

这样一来,就可以不传递 “实参” 了

// 设置一些带有默认值的参数

@mixinmy_transition($dur:1s,$pro:all,$delay:0s,$tim:linear) {

-webkit-transition:$dur$pro$delay$tim;

-moz-transition:$dur$pro$delay$tim;

-ms-transition:$dur$pro$delay$tim;

-o-transition:$dur$pro$delay$tim;

transition:$dur$pro$delay$tim;

}

使用的时候,如果你不传递,那么就是使用默认值

div{

width:100px;

height:100px;


// 使用的时候,只传递一个,剩下的使用默认值

@includemy_transition(2s);

}

编译结果

div{

width:100px;

height:100px;

-webkit-transition:2sall0slinear;

-moz-transition:2sall0slinear;

-ms-transition:2sall0slinear;

-o-transition:2sall0slinear;

transition:2sall0slinear;

}

继承

在 sass 里面使用继承可以大大的提高开发效率

其实继承很简单,就是把之前写过的选择器里面的内容直接拿过来一份

div{

width:100px;

height:100px;

background-color:pink;

}

这个是之前写过的一个规则样式表

接下来我要写另外一个样式了,发现我要写的一些内容和之前这个 div 一样,并且还有一些我自己的内容

那么我就可以把这个样式表先继承下来,再写我自己的内容就好了

p{

@extenddiv;

font-size:20px;

color:red;

}

编译结果

div,p{

width:100px;

height:100px;

background-color:pink;

}

p{

font-size:20px;

color:red;

}

注释

在 scss 文件中的注释分为几种

编译的时候不会被编译的注释

// 我是一个普通注释,在编译的时候,我就被过滤了

编译的时候会被编译的注释

/* 我在编译的时候,会被一起编译过去 */

强力注释

/*! 我是一个强力注释,不光编译的时候会被编译过去,将来压缩文件的时候也会存在 */

导入文件

我们刚才学过了定义变量,定义混合器

而这两个内容在定义过以后,如果没有使用,是不会被编译出内容的

所以我们可以把变量单独写一个文件,混合器单独写一个文件,然后直接导入后使用

// 我是 variable.scss

$w:100px;

$h:200px;

$c:pink;

// 我是 mixin.scss

@mixinmy_transition($dur:1s,$pro:all,$delay:0s,$tim:linear) {

-webkit-transition:$dur$pro$delay$tim;

-moz-transition:$dur$pro$delay$tim;

-ms-transition:$dur$pro$delay$tim;

-o-transition:$dur$pro$delay$tim;

transition:$dur$pro$delay$tim;

}

@mixinradius{

-webkit-border-radius:10px;

-moz-border-radius:10px;

-ms-border-radius:10px;

-o-border-radius:10px;

border-radius:10px;

}

然后在我们的主要文件中把这个两个文件导入进来就行了

// 我是 index.scss

@import'./variable.scss';

@import'./mixin.scss';

div{

width:$w;

height:$h;

background-color:$c;

@includeradius;

}

h1{

@includemy_transition;

}

编译结果

div{

width:100px;

height:200px;

background-color:pink;

-webkit-border-radius:10px;

-moz-border-radius:10px;

-ms-border-radius:10px;

-o-border-radius:10px;

border-radius:10px;

}

h1{

-webkit-transition:1sall0slinear;

-moz-transition:1sall0slinear;

-ms-transition:1sall0slinear;

-o-transition:1sall0slinear;

transition:1sall0slinear;

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,084评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,623评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,450评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,322评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,370评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,274评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,126评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,980评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,414评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,599评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,773评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,470评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,080评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,713评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,852评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,865评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,689评论 2 354

推荐阅读更多精彩内容

  • 一、Sass 和 SCSS 有什么区别? 文件扩展名不同,Sass 是以“.sass”后缀为扩展名,而 SCSS ...
    sskingfly阅读 263评论 0 0
  • 本文简单的介绍SASS预处理语言,更多的应用请参考官方文档 一、什么是SASS 二、为什么使用SASS 三、安装S...
    CharlesDarwin阅读 432评论 0 0
  • 1.1CSS 基础与选择器初识 | CSS 1. CSS 加载方式有几种? CSS样式加载一共有四种方式: 1、行...
    没糖_cristalle阅读 718评论 0 0
  • 一、什么是SASS SASS是一种CSS的开发工具,提供了许多便利的写法,大大节省了设计者的时间,使得CSS的开发...
    刘佳音阅读 379评论 0 1
  • 安装ruby http://rubyinstaller.org/downloads/ 淘宝镜像 https://g...
    阿布爱布丁阅读 589评论 0 0