一、什么是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 |
|
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 |
|
3)嵌套
标签嵌套
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
属性嵌套:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
4)注释
sass有两种注释风格
标准css注释: /* 注释 */, 会保留到编译后的文件中,压缩则删除
单行注释: // 注释
在标准注释 /*后面加入一个感叹号,表示重要注释,压缩模式也会保留注释,用于版权声明等。
1 |
|
5)继承
sass 中,选择器继承可以让选择器继承另一个选择器的所有样式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
使用占位符选择器 %
从sass3.2.0后,就可以定义占位选择器%,这个的优势在于,不调用不会有多余的css文件
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
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 |
|
@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 |
|
使用@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 |
|
7)颜色函数
sass提供了一些内置的颜色函数
1 2 3 4 |
|
8)引入外部文件
使用 @import 命令引入外部文件, 引入后,可使用外部文件中的变量等。
1 |
|
三、高级用法
1)函数 function
sass允许用户编写自己的函数,以@function开始
1 2 3 4 5 6 7 8 9 10 11 |
|
2)if条件语句
@if语句可以用来判断
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
三目判断:语法为 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 |
|
while循环
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
@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 |
|
多字段list数据循环
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
多字段map数据循环
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
原文地址:https://blog.csdn.net/weixin_46272787/article/details/135814209
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_62195.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!