常用的sass语法-sass总结笔记sass基础知识快速开发

58 阅读1分钟

一、变量

所有变量以$开头

//定义变量
$font_size: 12px;

//使用变量
.container{
 font-size: $font_size;
}

如果变量嵌套在字符串中,需要写在#{}中

$side : left;
.rounded {
 border-#{$side}: 1px solid #000;
}

二、嵌套

层级嵌套

.container{

    display: none;

    .header{

       width: 100%;

    }

}

属性嵌套,注意,border后需要加上冒号:

.container {
    border: {
        width: 1px;
    }
}

可以通过&引用父元素,常用在各种伪类

.link{
 &:hover{
 color: green;
 } 
}

三、mixin

简单理解,是可以重用的代码块,通过@include 命令

// mixin
@mixin focus_style {
 outline: none;
}

div {
 @include focus_style;
}

编译后生成

div {
 outline: none; 
}
还可指定参数、缺省值

// 参数、缺省值
@mixin the_height($h: 200px) {
 height: $h;
}
.box_default {
 @include the_height;
}
.box_not_default{
 @include the_height(100px);
}

编译后生成

.box_default {
 height: 200px; 
}

.box_not_default {
 height: 100px; 
}

四、继承

通过@extend,一个选择器可以继承另一个选择器的样式。例子如下

// 继承
.class1{
  float: left;
}

.class2{
  @extend .class1;
  width: 200px;
}

编译后生成

.class1, .class2 {
  float: left; 
}

.class2 {
  width: 200px; 
}

五、运算

直接上例子

.container{
    position: relative;
    height: (200px/2);
    width: 100px + 200px;
    left: 50px * 2;
    top: 50px - 10px;
​​​​​​​}

编译后生成

.container {
  position: relative;
  height: 100px;
  width: 300px;
  left: 100px;
  top: 40px;
}

插入文件

用@import 来插入外部文件

@import "outer.scss";

也可插入普通css文件

@import "outer.css";

自定义函数

通过@function 来自定义函数

@function higher($h){
        @return $h * 2;
​​​​​​​}
.container{
        height: higher(100px);
}

编译后输出

.container {
 height: 200px; 
}