scss 语法

每一种语言都有对应的包管理工具

python是pip
node是npm、pnpm
rufo是cargo
go是go
dart有pub – 适合做爬虫 --全栈语言
Ruby有gem 是国外的

第一章、css与预处理器
1.1、css

缺点:

无法嵌套书写,代码繁重、冗杂、逻辑混乱
没有变量与样式复用机制,属性值只能以字面量的形式重复输出

总结:

代码复用性低;不易于维护注:
现在的CSS是可以定义变量的!!!

1.2、预处理器:SCSS、LESS、Stylus

1、SCSS/SASS

SASS(.scss),于2007年诞生,最早也是最成熟的CSS预处理器,拥有ruby社区的支持和compass这一最强大的css框架,目前受LESS影响,已经进化到了全面兼容CSS的SCSS。

2、LESS

LESS(.less)。于2009年诞生,借鉴了SASS的长处,并兼容了CSS语法,使得开发者使用起来更为方便顺手,但是相比于SASS,其编程功能不够丰富,反而促使SASS进化成为了SCSS。

3、Stylus

Stylus(.styl)。于2010年诞生,出自Node.js社区,主要用来给Node项目进行CSS预处理支持,人气较前两者偏低。


1.3、SASS的两套语法:后缀 .sass、 .scss

sass有两套语法

1、sass,版本3.0之前的,后缀.sass

特点:使用缩进表示选择器的嵌套;使用换行符而不是;分割属性 -----反人类

2、scss,版本3.0之后,后缀为scss

特点:scss和css的缩进规范是一样的

优势:

完全兼容css3
在CSS基础上增加变量、嵌套(nesting)、混合(mixins)、选择器、继承等功能
通过函数进行颜色伯与属性值的运算
提供控制指令(control directives)等高级功能
自定义输出格式

  • 注:less、scss(sass)和stylus代码并不能被浏览器直接解析,所以必须先将它们编译成css代码现有框架已经提供了css预处理器选项,编译相关配置会自动帮我们生成!
第二章、sass的安装与配置
2.1、node环境下安装node-sass

node-sass与node版本关系
在这里插入图片描述

npm i sass-resources-loader -S   //sass-resources-loader加载器
npm install -g node-gyp
npm install --global --production windows-build-tools
npm install sass-loader@7.3.1 --save-dev
npm i sass-loader@7.3.1 -g

npm install node-sass@4.14.1 --save-dev   我
cnpm install node-sass@7.3.1   //三维用到的
npm install sass-loader@8.0.2 -g   这个版本可能过高,报错信息
Module build failed: TypeError: this.getResolve is not a function     at Object.loader 
(E:\workspace\babylon_demo\node_modules\sass-loader\dist\index.js:52:26
换成
npm install sass-loader@7.3.1    //用的这个
node-sass -v   查看是否安装成功
"node-sass": "^4.12.0",
"sass-loader": "^7.3.1",

写全局样式:在assets中新建sass文件夹,新增index.scss,,,,

在main.js中引入,,(一定要引入,不然不生效)

import './assets/sass/index.scss'
2.2、依赖编辑器

1)webstorm ,需要配置自动命令,另安装一个代码提示插件scss

2)vscode,安装Easy Sass(编译)和Sass(代码提示)两个插件

演示–webstorm配置scss

安装上述命令行工具之一(以node-sass为例演示)

依次打开并点击:webstrom->Settings>Tools>Files Watchers>+>选择SCSS文件标识

Name随意写,供自己看而已
File Type选择SCSS Style Sheet
Scope选择All Places
Program选择可执行文件的路径(这里以node-sass为例)
Arguments按选择(这里以sFileName5:5FileNameWithoutExtension . c s s 为例) O u t p u t p a t h s t o r e f r e s h 按常选择(这 .css为例) Output paths to refresh按常选择(这 .css为例)Outputpathstorefresh按常选择(这FileNamewWithoutExension$.css为例)
点击OK,配置完成

在这里插入图片描述

在这里插入图片描述

2.3、在vue.config.js中配置scss

在asstes文件夹下建立一个scss文件夹 然后创建一个 _variable.scss文件 用来存储全局变量。
在vue.config.js中配置 sass

css: {
    loaderOptions: {
      sass: {
        prependData: `@import "@/assets/scss/_variable.scss";` //引入全局变量   
      }
    }
  }
第三章、SassScript == scss语法

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

弱类型语言,对语法要求没那么严格

3.1、注释
  1. Sass 支持标准的 CSS 多行注释 /* */,以及单行注释 //,前者会被完整输出到编译后的 CSS 文件中,而后者则不会。

  2. ! 作为多行注释的第一个字符表示在压缩输出模式下保留这条注释并输出到 CSS 文件中,通常用于添加版权信息。

  3. 插值语句 (interpolation) 也可写进多行注释中输出变量值

/* 
   hello
   world!
*/
// it's ready to do it.
/*!
   Author: #{$author}.
*/
3.2、变量

1.定义:$width: 1600px;

2.使用:直接使用变量的名称即可调用变量

3.作用域:变量支持块级作用域,嵌套规则内定义的变量只能在嵌套规则内使用(局部变量),不在嵌套规则内定义的变量则可在任何地方使用(全局变量)。

将局部变量转换为全局变量可以添加 !global 声明

#foo {$width: 5em !global;width: $width;}   #bar {width: $width;}
//编译后:
#foo {   width: 5em;}        #bar {width: 5em;}
3.3、数据类型

支持 7 种主要的数据类型:

数字,1, 2, 13, 10px
字符串,有引号字符串与无引号字符串,"foo", 'bar', baz
颜色,blue, #04a3f9, rgba(255,0,0,0.5)
布尔型,true, false    //$a: true;$b: false;  只有自身是false和null才会返回false,其他一切都将返回true
空值,null     $value: null;  由于它代表空,所以不能够使用它与任何类型进行算数运算
数组 (list),用空格或逗号作分隔符,1.5em 1em 0 2em, Helvetica, Arial, sans-serif
maps, 相当于 JavaScript 的 object,(key1: value1, key2: value2)

SassScript 也支持其他 CSS 属性值,比如 Unicode 字符集,或 !important 声明。然而Sass 不会特殊对待这些属性值,一律视为无引号字符串。

判断数据类型的方式:type-of($value)

1.字符串 (Strings)

两种字符串类型:有引号字符串 (quoted strings),和无引号字符串 (unquoted strings)

$container: "top bottom";
$what: heart;

在编译 CSS 文件时不会改变其类型。只有一种情况例外,使用 #{} (interpolation) 时,有引号字符串将被编译为无引号字符串,这样便于在 mixin 中引用选择器名

2.数字(Numbers)

两种数字类型:带单位数字不带单位数字。(可正可负可为零,可正可浮点)

$my-age: 19;
$your-age: 19.5;
$height: 120px;
// 注:单位会和数字当做一个整体,进行算数运算

5.数组 (Lists)

$list0: 1px 2px 5px 6px;
$list1: 1px 2px, 5px 6px;
$list2: (1px 2px) (5px 6px);

数组中可以包含子数组,比如 1px 2px, 5px 6px 是包含 1px 2px5px 6px 两个数组的数组。如果内外两层数组使用相同的分隔方式,需要用圆括号包裹内层,所以也可以写成 (1px 2px) (5px 6px)。变化是,之前的 1px 2px, 5px 6px 使用逗号分割了两个子数组 (comma-separated),而 (1px 2px) (5px 6px) 则使用空格分割(space-separated)。

当数组被编译为 CSS 时,Sass 不会添加任何圆括号(CSS 中没有这种写法),所以 (1px 2px) (5px 6px)1px 2px, 5px 6px 在编译后的 CSS 文件中是完全一样的,但是它们在 Sass 文件中却有不同的意义,前者是包含两个数组的数组,而后者是包含四个值的数组。

() 表示不包含任何值的空数组(在 Sass 3.3 版之后也视为空的 map)。空数组不可以直接编译成 CSS,比如编译 font-family: () Sass 将会报错。如果数组中包含空数组或空值,编译时将被清除,比如 1px 2px () 3px1px 2px null 3px

基于逗号分隔的数组允许保留结尾的逗号,这样做的意义是强调数组的结构关系,尤其是需要声明只包含单个值的数组时。例如 (1,) 表示只包含 1 的数组,而 (1 2 3,) 表示包含 1 2 3 这个以空格分隔的数组的数组。

6.映射(Maps)

Maps必须被圆括号包围,可以映射任何类型键值对(任何类型,包括内嵌maps,不过不推荐这种内嵌方式)

$map: ( 
  $key1: value1, 
  $key2: value2, 
  $key3: value3 
)

7.颜色 (Colors)

CSS原有颜色类型,十六进制、RGB、RGBA、HSL、HSLA和色彩单词

SCSS提供了内置Colors函数,从而更方便地使用颜色

$color0: green;
$color1: lighten($color, 15%);  //减轻
$color2: darken($color, 15%);  //加深
$color3: saturate($color, 15%);  //提高传入颜色的色彩饱和度。等同于 adjust-color( color, saturation: amount)
$color4: desaturate($color, 15%);//调低一个颜色的饱和度后产生一个新的色值。同样,饱和度的取值区间在 0% ~ 100%。等同于 adjust-color(color, saturation: -amount)
$color5: (green + red);
3.4、运算

1.数字运算符

支持数字的加减乘除、取整等运算 (+, -, *, /, %),如果必要会在不同单位间转换值

+

a.纯数字:只要有单位,结果必有单位

b.纯字符串:第一个字符串有无引号决定结果是否有引号

c数字和字符串:第一位有引号,结果必为引号;第一位对应数字非数字且最后一位带有引号,则结果必为引号

/ 纯数字
  $add1: 1 + 2;    // 3	$add2: 1 + 2px; // 3px	$add3: 1px + 2; // 3px		$add4: 1px + 2px;//3px
  // 纯字符串
  $add5: "a" + "b"; // "ab"	$add6: "a" + b;    // "ab"	$add7: a + "b";    // ab	$add8: a + b;      // ab
  // 数字和字符串
  $add9: 1 + a;    // 1a
  $adda: a + 1;    // a1
  $addb: "1" + a; // "1a"
  $addc: 1 + "a"; // "1a"
  $addd: "a" + 1; // "a1"
  $adde: a + "1"; // a1
  $addf: 1 + "1"; // "11"

-

每个字段必须前部分为数字,且两个字段只能一个后部分是字符(因为此时后缀被当被单位看待了)。

只要其中一个值首位不为数字的,结果就按顺序去除空格后拼接起来

 $add1: 1 - 2;    // -1
  $add2: 1 - 2px; // -1px
  $add3: 1px - 2; // -1px
  $add4: 1px - 2px;//-1px
  
  $sub1: a - 1;  // a-1
  $sub2: 1 - a;  // 1-a
  $sub3: "a" - 1;// "a"-1
  $sub4: a - "1";// a-"1"

*

每个字

段必须前部分为数字,且两个字段只能一个后部分是字符(因为此时后缀被当被单位看待了)。其余编译不通过

 $num1: 1 * 2;    // 2
  $mul2: 1 * 2px;  // 2px
  $num3: 1px * 2;  // 2px
  $num4: 2px * 2px;// 编译不通过
  $num5: 1 * 2abc; // 2abc

/

a.不会四舍五入,精确到小数点后5位

b.每个字段必须前部分为数字,且当前者只是单纯数字无单位时,后者(除数)后部分不能有字符。其余结果就按顺序去除空格后拼接起来。

(因为此时后缀被当被单位看待了)

%

a.值与"%"之间必须要有空格,否则会被看做字符串

2.关系运算符

大前提:两端必须为数字前部分数字后部分字符

返回值:true or false

>  $a: 1 > 2; // false
<  $a: 1 > 2; // true
>= $a: 1 >= 2; // false
<= $a: 1 <= 2; // true

3.相等运算符

作用范围:相等运算 ==, != 可用于所有数据类型

返回值:true or false

$a: 1 == 1px; // true
$b: "a" == a; // true

前部分为不带引号数字时,对比的仅仅是数字部分;反之,忽略引号,要求字符一一对应

4.布尔运算符

SassScript 支持布尔型的 and or 以及 not 运算。

$a: 1>0 and 0>=5; // fasle

值与"and"、"or"和"not"之间必须要有空格,否则会被看做字符串

5.颜色值运算

颜色值的运算是分段计算进行的,也就是分别计算红色,绿色,以及蓝色的值

颜色值与颜色值
 p { color: #010203 + #040506; }
  p {color: #050709; }

颜色值与数字

p { color: #010203 * 2;}
 p {color: #020406; }

RGB和HSL

如果颜色值包含 alpha channel(rgba 或 hsla 两种颜色值),必须拥有相等的 alpha 值才能进行运算,因为算术运算不会作用于 alpha 值。

 p {color: rgba(255, 0, 0, 0.75) + rgba(0, 255, 0, 0.75);}
 p {color: rgba(255, 255, 0, 0.75); }

6.运算优先级

0. ()
1. *`、`/`、`%
2. +、-
3. > 、<、>=、<=
3.5、嵌套语法
3.6、杂货语法

1.插值语法

通过 #{} 插值语句可以在选择器、属性名和属性值中使用变量。

$name: foo;	$attr: border;
p.#{$name} {
  #{$attr}-color: $name;}
p.foo { border-color: foo;}  // 编译后:

2.&

&为父选择器

a {
    color: yellow;
    &:hover{
        color: green;
    }
    &:active{
        color: blank;
    }
}

3.!default

可以在变量的结尾添加 !default 给一个未通过 !default 声明赋值的变量赋值,此时,如果变量已经被赋值,不会再被重新赋值,但是如果变量还没有被赋值,则会被赋予新的值。

$content: "First content";
$content: "Second content?" !default;
$new_content: "First time reference" !default;
#main {
  content: $content;
  new-content: $new_content;
}
// 编译为:
#main {
  content: "First content";
  new-content: "First time reference"; }
~~~
注意:变量是 null 空值时将视为未被 `!default` 赋值。

4.!global

将局部变量提升为全局变量

5.!optional

如果 @extend 失败会收到错误提示,比如,这样写 a.important {@extend .notice},当没有 .notice 选择器时,将会报错,只有 h1.notice 包含 .notice 时也会报错,因为 h1 与 a`冲突,会生成新的选择器。

如果要求 @extend不生成新选择器,可以通过 !optional 声明达到这个目的.

简而言之:当@extend相关代码出现语法错误时,编译器可能会给我们"乱"编译为css,我们加上这个参数可以在出现问题后不让他编译该部分代码

3.7、@-Rules与指令

1.@import

Sass 拓展了 @import 的功能,允许其导入 SCSS 或 SASS 文件。被导入的文件将合并编译到同一个 CSS 文件中,另外,被导入的文件中所包含的变量或者混合指令 (mixin) 都可以在导入的文件中使用。

通常,@import 寻找 Sass 文件并将其导入,但在以下情况下,@import 仅作为普通的 CSS 语句,不会导入任何 Sass 文件。

文件拓展名是 `.css`;
文件名以 `http://` 开头;
文件名是 `url()`;
`@import` 包含 media queries

如果不在上述情况内,文件的拓展名是 .scss.sass,则导入成功。没有指定拓展名,Sass 将会试着寻找文件名相同,拓展名为 .scss.sass 的文件并将其导入。

// 以上两种方式均可
@import "foo.scss";
@import "foo";
// 以下方式均不可行
@import "foo.css";
@import "foo" screen;
@import "http://foo.com/bar";
@import url(foo);
//Sass 允许同时导入多个文件,例如同时导入 rounded-corners 与 text-shadow 两个文件
@import "rounded-corners", "text-shadow";
//导入文件也可以使用 `#{ }` 插值语句,但不是通过变量动态导入 Sass 文件,只能作用于 CSS 的 `url()` 导入方式
$family: unquote("Droid+Sans");
@import url("http://fonts.googleapis.com/css?family=\#{$family}");
@import url("http://fonts.googleapis.com/css?family=Droid+Sans");   // 编译为

如果你有一个 SCSS 或 Sass 文件需要引入, 但是你又不希望它被编译为一个 CSS 文件, 这时,你就可以在文件名前面加一个下划线,就能避免被编译。 这将告诉 Sass 不要把它编译成 CSS 文件。 然后,你就可以像往常一样引入这个文件了,而且还可以省略掉文件名前面的下划线。

除此之外,还支持嵌套 @import,但是不可以在混合指令 (mixin) 或控制指令 (control directives) 中嵌套 @import

2.@media

Sass 中 @media 指令与 CSS 中用法一样,只是增加了一点额外的功能:允许其在 CSS 规则中嵌套。如果 @media嵌套在 CSS 规则内,编译时,@media将被编译到文件的最外层,包含嵌套的父选择器。这个功能让 @media 用起来更方便,不需要重复使用选择器,也不会打乱 CSS 的书写流程。

// @media的 queries 允许互相嵌套使用,编译时,Sass 自动添加 `and`
@media screen {
  .sidebar {
    @media (orientation: landscape) {
      width: 500px;
    }
  }
}
@media screen and (orientation: landscape) {  // 编译为:
  .sidebar {
    width: 500px; } }
 //@media 甚至可以使用 SassScript(比如变量,函数,以及运算符)代替条件的名称或者值 
 $media: screen;
$feature: -webkit-min-device-pixel-ratio;
$value: 1.5;
@media #{$media} and ($feature: $value) {
  .sidebar {
    width: 500px;
  }
}
@media screen and (-webkit-min-device-pixel-ratio: 1.5) {  // 编译为:
  .sidebar {
    width: 500px; } }  

3.@extend

@extend即继承。在设计网页的时候常常遇到这种情况:一个元素使用的样式与另一个元素完全相同,但又添加了额外的样式。

总的来看:支持层叠继承、多继承、允许延伸任何定义给单个元素的选择器(但是允许不一定好用)

a. 基本延伸

.error {
  border: 1px #f00;
  background-color: #fdd;
}
.seriousError {
  @extend .error;
  border-width: 3px;
}
`@extend` 的作用是将重复使用的样式 (`.error`) 延伸 (extend) 给需要包含这个样式的特殊样式(`.seriousError`)

b. 延伸复杂的选择器:Class 选择器并不是唯一可以被延伸 (extend) 的,Sass 允许延伸任何定义给单个元素的选择器,比如 .special.coola:hover 或者 a.user[href^="http://"]

c. 多重延伸:同一个选择器可以延伸给多个选择器,它所包含的属性将继承给所有被延伸的选择器

d. 继续延伸:当一个选择器延伸给第二个后,可以继续将第二个选择器延伸给第三个

e.*选择器列:暂时不可以将选择器列 (Selector Sequences),比如 .foo .bar.foo + .bar,延伸给其他元素,但是,却可以将其他元素延伸给选择器列。

尽量不使用合并选择器列,因为如果凭个人推理的话,会出现排列组合的情况,所以SASS编译器只会保留有用的组合形式,但依旧会存在排列组合的情况,有可能会留下隐患。

  1. 当两个列合并时,如果没有包含相同的选择器,将生成两个新选择器:第一列出现在第二列之前,或者第二列出现在第一列之前
 #admin .tabbar a {
     font-weight: bold;
   }
   #demo .overview .fakelink {
     @extend a;
   }
   // 编译为:
   #admin .tabbar a,
   #admin .tabbar #demo .overview .fakelink,
   #demo .overview #admin .tabbar .fakelink {
     font-weight: bold; }
  1. 如果两个列包含了相同的选择器,相同部分将会合并在一起,其他部分交替输出
 #admin .tabbar a {
     font-weight: bold;
   }
   #admin .overview .fakelink {
     @extend a;
   }
   // 编译为
   #admin .tabbar a,
   #admin .tabbar .overview .fakelink,
   #admin .overview .tabbar .fakelink {
     font-weight: bold; }

f. 在指令中延伸

在指令中使用 @extend 时(比如在 @media 中)有一些限制:Sass 不可以将 @media 层外的 CSS 规则延伸给指令层内的 CSS.

g. %placeholder为选择器占位符,配合@extend-Only选择器使用。

效果:只定义了样式,但不会对原有选择器匹配的元素生效

%img {
    color: red;
}
.path{
    @extend %img;
}
// 编译后:
.path {
  color: red;
}
// example2:
#context a%extreme {
  color: blue;
  font-weight: bold;
  font-size: 2em;
}
// 编译后:
.notice {
  @extend %extreme;
}
// 注:必须是"."和"#"选择器

4.@at-root

@at root指令使一个或多个规则在文档的根发出,而不是嵌套在其父选择器下。它可以与单个内联选择器一起使用

且@at-root 使多个规则跳出嵌套

@at-root默认情况下并不能使规则或者选择器跳出指令,通过使用without和with可以解决该问题

5.@debug

用于调试,按标准错误输出流输出

.file{
  @debug $size;
}

6.@warn

用于警告,按标准错误输出流输出

7.@error

用于报错,按标准错误输出流输出

| 序列 | @-rules  | 作用                               |
| ---- | -------- | ---------------------------------- |
| 1    | @import  | 导入sass或scss文件                 |
| 2    | @media   | 用于将样式规则设置为不同的媒体类型 |
| 3    | @extend  | 以继承的方式共享选择器             |
| 4    | @at-root | 转到根节点                         |
| 5    | @debug   | 用于调试,按标准错误输出流输出     |
| 6    | @warn    | 用于警告,按标准错误输出流输出     |
| 7    | @error   | 用于报错,按标准错误输出流输出     |
3.8、控制指令

1.if()

p { color: if(1 + 1 = 2, green, yellow);}
p{color: green;}

2.@if

条件语句

@if 的表达式返回值不是 false 或者 null 时,条件成立,输出 {} 内的代码

@if 声明后面可以跟多个 @else if 声明,或者一个 @else 声明。如果 @if 声明失败,Sass 将逐条执行 @else if 声明,如果全部失败,最后执行 @else 声明

@if

 p {
        @if 1 + 1 == 2 {
            color: red;
        }
    }
    p {
      color: red;
    }

@if - @else

p {
      @if 1 + 1 != 2 {
          color: red;
      } @else {
          color: blue;
      }
  }
  p {
    color: blue;
  }

@if - @else if - @else

 $age: 19;    
  p {
      @if $age == 18 {
          color: red;
      } @else if $age == 19 {
          color: blue;
      } @else {
          color: green;
      }
  }  
  // compile:
  p {
    color: blue;
  }

3.@for

循环语句

表达式:@for $var from through @for $var from to

through 和 to 的相同点与不同点:

- 相同点:两者均包含的值

- 不同点:through包含的值,但to不包含的值

@for $i from 1 through 3 {
  .item-#{$i} { width: 2em * $i; }
}
.item-1 {
  width: 2em; }
.item-2 {
  width: 4em; }
.item-3 {
  width: 6em; }

4.@while

循环语句

表达式:@while expression

@while 指令重复输出格式直到表达式返回结果为 false。这样可以实现比 @for 更复杂的循环,只是很少会用到

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

5.@each

循环语句

循环语句

表达式:$var in $vars

$var 可以是任何变量名

$vars` 只能是`Lists`或者`Maps

一维列表

 @each $animal in puma, sea-slug, egret, salamander {
    .#{$animal}-icon {
      background-image: url('/images/#{$animal}.png');
    }
  }
  // compile:
  .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'); }
  .salamander-icon {
    background-image: url('/images/salamander.png'); }

二维列表

  @each $animal, $color, $cursor in (puma, black, default),
                                    (sea-slug, blue, pointer),
                                    (egret, white, move) {
    .#{$animal}-icon {
      background-image: url('/images/#{$animal}.png');
      border: 2px solid $color;
      cursor: $cursor;
    }
  }
  // compile:
  .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; }
  .egret-icon {
    background-image: url('/images/egret.png');
    border: 2px solid white;
    cursor: move; }

maps

  @each $header, $size in (h1: 2em, h2: 1.5em, h3: 1.2em) {
    #{$header} {
      font-size: $size;
    }
  }
  // compile:
  h1 {
    font-size: 2em; }
  h2 {
    font-size: 1.5em; }
  h3 {
    font-size: 1.2em; }
3.9、混合指令

混合指令(Mixin)用于定义可重复使用的样式,避免了使用无语意的 class,比如 .float-left。混合指令可以包含所有的 CSS 规则,绝大部分 Sass 规则,甚至通过参数功能引入变量,输出多样化的样式

注意:这不是函数!没有返回值!!

1.定义混合指令

混合指令的用法是在 @mixin 后添加名称与样式,以及需要的参数(可选)

@mixin name {
    // 样式....
}
// example:
@mixin large-text {
  font: {
    family: Arial;
    size: 20px;
    weight: bold;
  }
  color: #ff0000;
}

@content

@content这个是不是个类似占位用的,代表里面是自定义的的

@content用在mixin里面的,当定义一个mixin后,并且设置了@content; @include的时候可以传入相应的内容到mixin里面

$color: white;
@mixin colors($color: blue) {
  background-color: $color;
  @content;
  border-color: $color;
}
.colors {
  @include colors { color: $color; }
}

2.引用混合样式

使用 @include 指令引用混合样式,格式是在其后添加混合名称,以及需要的参数(可选)。

@include name; // 格式:
// 注:无参数或参数都有默认值时,带不带括号都可以
// example:
p {
    @include large-text;
}
// compile:
p {
  font-family: Arial;
  font-size: 20px;
  font-weight: bold;
  color: #ff0000;
}

3.参数

格式:按照变量的格式,通过逗号分隔,将参数写进Mixin名称后的圆括号里

支持默认值;支持多参数;支持不定参数;支持位置传参和关键词传参

a. 位置传参

@mixin mp($width) {
    margin: $width;
}

body {
    @include mp(300px);
}

b.关键词传参

@mixin mp($width) {
    margin: $width;
}
body {
    @include mp($width: 300px);
}

c.参数默认值

@mixin mp($width: 500px) {
    margin: $width;
}
body {
    @include mp($width: 300px);
    // or
    @include mp(300px);
}

d.不定参数

有时,不能确定混合指令需要使用多少个参数。这时,可以使用参数变量 声明(写在参数的最后方)告诉 Sass 将这些参数视为值列表处理

@mixin mar($value...) {
    margin: $value;
}

4.向混合样式中导入内容

在引用混合样式的时候,可以先将一段代码导入到混合指令中,然后再输出混合样式,额外导入的部分将出现在 @content 标志的地方

可以看作参数的升级版

@mixin example {
    html {
        @content;
    }
}
@include example{
    background-color: red;
    .logo {
        width: 600px;
    }
}
// compile:
html {
  background-color: red;
}

html .logo {
  width: 600px;
}
3.10、函数指令

1.内置函数

a. 字符串函数

索引第一个为1,最后一个为-1;切片两边均为闭区间

| 函数名和参数类型                           |                  函数作用                   |
| quote($string)                          |                  添加引号                   |
| unquote($string)                        |                  除去引号                   |
| to-lower-case($string)                  |                  变为小写                   |
| to-upper-case($string)                  |                  变为大写                   |
| str-length($string)                     |        返回$string的长度(汉字算一个)        |
| str-index($string,$substring)          |        返回$substring在$string的位置        |
| str-insert($string, $insert, $index)    |       在$string的$index处插入$insert        |
| str-slice($string, $start-at, $end-at) | 截取$string的$start-at和$end-at之间的字符串 |

b. 数字函数

| 函数名和参数类型           |                           函数作用                           |
| percentage($number)     |                       转换为百分比形式                       |
| round($number)          |                        四舍五入为整数                        |
| ceil($number)           |                         数值向上取整                         |
| floor($number)          |                         数值向下取整                         |
| abs($number)            |                          获取绝对值                          |
| min($number...)         |                          获取最小值                          |
| max($number...)         |                          获取最大值                          |
| random($number?:number) | 不传入值:获得0-1的随机数;传入正整数n:获得0-n的随机整数(左开右闭) |

c. 数组函数

| 函数名和参数类型                    |                           函数作用                           |
| length($list)                    |                         获取数组长度                         |
| nth($list, n)                    |                      获取指定下标的元素                      |
| set-nth($list, $n, $value)       |                   向$list的$n处插入$value                    |
| join($list1, $list2, $separator) | 拼接$list1和list2;$separator为新list的分隔符,默认为auto,可选择comma、space |
| append($list, $val, $separator)  | 向$list的末尾添加$val;$separator为新list的分隔符,默认为auto,可选择comma、space |
| index($list, $value)             |                返回$value值在$list中的索引值                 |
| zip($lists…)                     | 将几个列表结合成一个多维的列表;要求每个的列表个数值必须是相同的 |

d. 映射函数

| 函数名和参数类型           |                 函数作用                 |
| map-get($map, $key)     |        获取$map中$key对应的$value        |
| map-merge($map1, $map2) |     合并$map1和$map2,返回一个新$map     |
| map-remove($map, $key)  |     从$map中删除$key,返回一个新$map     |
| map-keys($map)          |            返回$map所有的$key            |
| map-values($map)        |           返回$map所有的$value           |
| map-has-key($map, $key) | 判断$map中是否存在$key,返回对应的布尔值 |
| keywords($args)         |  返回一个函数的参数,并可以动态修改其值  |

e. 颜色函数
在这里插入图片描述

.xkd{    content:fade-in(rgba(100, 100, 255, 0.7), 0.1);}     .xkd {  content: rgba(100, 100, 255, 0.8);}    0.7+0.1=0.8
.xkd{    content:fade-out(rgba(100, 100, 255, 0.7), 0.1);}    .xkd {  content: rgba(100, 100, 255, 0.6);}     0.7-0.1=0.6

RGB函数

 | 函数名和参数类型                   |                           函数作用                           |
  | rgb($red, $green, $blue)       |                     返回一个16进制颜色值                     |
  | rgba($red,$green,$blue,$alpha) | 返回一个rgba;$red,$green和$blue可被当作一个整体以颜色单词、hsl、rgb或16进制形式传入 |
  | red($color)                    |                   从$color中获取其中红色值                   |
  | green($color)                  |                   从$color中获取其中绿色值                   |
  | blue($color)                   |                   从$color中获取其中蓝色值                   |
  | mix($color1,$color2,$weight?)  |     按照$weight比例,将$color1和$color2混合为一个新颜色      |

HSL函数

| 函数名和参数类型                             | 函数作用                                                     |
  | hsl($hue,$saturation,$lightness)         | 通过色相(hue)、饱和度(saturation)和亮度(lightness)的值创建一个颜色 |
  | hsla($hue,$saturation,$lightness,$alpha) | 通过色相(hue)、饱和度(saturation)、亮度(lightness)和透明(alpha)的值创建一个颜色 |
  | saturation($color)                       | 从一个颜色中获取饱和度(saturation)值                       |
  | lightness($color)                        | 从一个颜色中获取亮度(lightness)值                          |
  | adjust-hue($color,$degrees)              | 通过改变一个颜色的色相值,创建一个新的颜色                   |
  | lighten($color,$amount)                  | 通过改变颜色的亮度值,让颜色变亮,创建一个新的颜色           |
  | darken($color,$amount)                   | 通过改变颜色的亮度值,让颜色变暗,创建一个新的颜色           |
  | hue($color)                              | 从一个颜色中获取亮度色相(hue)值                            |

Opacity函数

  | alpha($color)/opacity($color)                               | 获取颜色透明度值 |
  | rgba($color,$alpha)                                         | 改变颜色的透明度 |
  | opacify($color, $amount) / fade-in($color, $amount)         | 使颜色更不透明   |
  | transparentize($color, $amount) / fade-out($color, $amount) | 使颜色更加透明   |

Introspection函数

| 函数名和参数类型                  |                           函数作用                           |
| type-of($value)                |                       返回$value的类型                       |
| unit($number)                  |                      返回$number的单位                       |
| unitless($number)              |           判断$number是否带单位,返回对应的布尔值            |
| comparable($number1, $number2) | 判断$number1和$number2是否可以做加、减和合并,返回对应的布尔值 |

2.自定义函数

Sass 支持自定义函数,并能在任何属性值或 Sass script 中使用

Params: 与Mixin一致

支持返回值

**基本格式:**
~~~scss
@function fn-name($params...) {
    @return $params;
}
// example:
@function fn-name($params...) {
    @return nth($params, 1);
}
p {
    height: fn-name(1px);
}
// compiled:
p {
  height: 1px;
}
第四章、vue项目使用scss
4.1、细节

a. @extend、@Mixin和@function的选择

minxins在网络传输中比@extend 拥有更好的性能.尽管有些文件未压缩时更大,但使用gzip压缩后,依然可以保证我们拥有更好的性能。

所以@extend我们就尽量不要使用了,而@Mixin和@function的差别在定义和使用上

定义方式不同: @function 需要调用@return输出结果。而 @mixin则不需要。

使用方式不同:@mixin 使用@include引用,而 @function 使用小括号执行函数。

4.2、vue项目全局引入scss/sass文件

以上内容算是"基础"部分,但是对于日常开发,足够使用

如果想要进一步了解,就必须先去学习下Ruby,使用Ruby相关模块进行更丰富地学习
在这里插入图片描述

4.3、Vue + Scss 动态切换主题颜色 === 换皮肤

给html根标签设置一个data-theme属性,然后通过js切换data-theme的属性值,Scss根据此属性来判断使用对应主题变量。这里可以选择持久化Vux或接口来保存用户选择的主题。

  1. .新建一个Scss文件_theme.scss,里面可以配置不同的主题配色方案
    在这里插入图片描述
$themes:(
 light:(
  header-background-color:#2e41a5,
  main-background-color:#fff,
  footer-background-color:rgb(246,246,246)

 ),
 dark:(
   header-background-color:#000,
   main-background-color:rgba(0,0,0,0.9),
   footer-background-color:rgb(47,50,58)
 )
)

这里定义了一个map–$themes,分别存放对应主题的颜色变量集合。

注意,scss文件名建议用下划线开头,如_themes.scss,防止执行时被编译成单独的css文件。

2.定义另外一个sass文件index.scss来操作1中的$themes变量(分开写是想把配置和操作解耦)

@import "./_theme.scss";
@mixin themeify {
  @each $theme-name, $theme-map in $themes {
    //!global 把局部变量强升为全局变量
    $theme-map: $theme-map !global;
    //判断html的data-theme的属性值  #{}是sass的插值表达式
    //& sass嵌套里的父容器标识   @content是混合器插槽,像vue的slot
    [data-theme="#{$theme-name}"] & {
      @content;
    }
  }
}
@function themed($key) {
  @return map-get($theme-map, $key);
}
//获取背景颜色
@mixin background_color($color) {
  @include themeify {
    background-color: themed($color)!important;
  }
}
//获取字体颜色
@mixin font_color($color) {
  @include themeify {
    color: themed($color)!important;
  }
}
//获取边框颜色
@mixin border_color($color) {
  @include themeify {
    border-color: themed($color)!important;
  }
}

themeify方法用于获取HTML的 data-theme值。
themed方法用于根据HTML的 data-theme值及调用者传过来的key去 _themes.scss里获取相应的颜色。

上面可以根据自己的使用场景自定义混入器,上面只定义了三个常用的背景&边框&字体的颜色。

  1. 具体在vue中使用,直接引入对应混入器就好,取哪个颜色,传哪个key
<style lang="scss" scoped>
@import "@/styles/theme/index.scss";

@include b(header) {
  height: 64px;
  @include background_color("header-background-color");
  padding: 0 5vw;
  color: #fff;
::v-deep.el-menu .el-menu-item{
    @include background_color("header-background-color");
    &:hover{
        @include background_color("header-background-color");;    
        color: #FF3C00 ;
    }
}
  1. 使用js动态切换HTML的属性data-theme的值
//templete中
<el-icon class="each_menu" :size="20" @click="changeCurTheme('dark')"   v-if="curTheme === 'light'" >
         <Sunny />
</el-icon>
 <el-icon class="each_menu" :size="20" @click="changeCurTheme('light')"   v-else>
        <Moon  />
</el-icon>

//script中
const curTheme = ref(localStorage.getItem('theme'))   //定义变量
function changeCurTheme(themeName) {
  curTheme.value = themeName
  localStorage.setItem('theme', themeName)
  window.document.documentElement.setAttribute( "data-theme", themeName );
}

切换后F12会发现 [data-theme=“dark”]
在这里插入图片描述

elementui-plus切换主题

切换主题 色:

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值