Scss基础用法

Scss基础用法

 

一、注释用法:

(1)//comment:该注释只是在.scss源文件中有,编译后的css文件中没有。

(2)/! /:重要注释,任何style的css文件中都会有,一般放置css文件版权说明等信息。

(3)/ /:该注释在compressed的style的css中没有,其他style的css文件都会含有。

 

二、变量:

1.一般以$开头,有作用域限制

$color: red;
.div{
    background-color: $color;    
}

 

2.若子选择器中定义的变量想成为全局变量,可以用!global

.div{
  $width: 5px !global;
  width: $width;
}

.p{
  width: $width;
}

 

3.嵌套引用,需#{}进行包裹

$left: left;
.div{
   border-#{$left}-width: 5px; 
}

 

4.计算

$left: 20px;
.div{
    margin-left: $left + 12px;
    margin-top: $left  / 2;
}

 

三、选择器

1.选择器嵌套(允许属性嵌套)

.div{
    .span{
        height: 12px;
    }
    .p{
        border: {
      color: red;
    }
    }
}

 

2.引用父元素(使用&符号)

.div{
    &:hover{
        cursor: pointer;
    }
}

 

四、代码复用

1.继承(若在div2后再加一个div1,也会影响div2的属性)

.div1{
    font-size: 14px;
}
.div2{
    @extend .div1;
    color: red;
}

 

2.引用外部的scss文件(文件路径建议用相对路径)

@import  ‘ ./test.scss’;

 

3.Mixin与Include

//使用@mixin命令,定义一个代码块
@mixin left {
  float: left;
  margin-left: 5px;
}

//使用@include命令,调用这个mixin代码块
div {
  @include left;
}

 

五、参数

eg1:

@mixin common($value1, $value2, $defaultValue: 5px){
    display: block;
    margin-left: $value1;
    margin-right: $value2;
    padding: $defaultValue;
}
.div1{
    font-size: 8px;
    @include common(11px, 13px, 15px);
}
.div2{
    font-size: 8px;
    @include common(11px, 13px);
}

 

eg2:

//生成浏览器前缀。
  @mixin rounded($vert, $horz, $radius: 10px) {
    border-#{$vert}-#{$horz}-radius: $radius;
    -moz-border-radius-#{$vert}#{$horz}: $radius;
    -webkit-border-#{$vert}-#{$horz}-radius: $radius;
  }

//使用的时候调用:
  #navbar li { @include rounded(top, left); }
  #footer { @include rounded(top, left, 5px); }

 

六、条件语句

可以用@if(){}来判断,也可以用@if(){}@else来判断

@if lightness($color) > 30% {
  background-color: #000;
} @else {
  background-color: #fff;
}

 

七、循环语句

1.for循环

@for $i from 1 to 10 {
  .border-#{$i} {
    border: #{$i}px solid blue;
  }
}

 

2.while循环

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

 

3.each(类似于for)

@each $member in a, b, c, d {
  .#{$member} {
    background-image: url("/image/#{$member}.jpg");
  }
}

 

八、函数

可以自定义函数

@function double($n) {
  @return $n * 2;
}

#sidebar {
  width: double(5px);
}

 

posted @ 2018-06-01 13:16  慕容冰菡  阅读(439)  评论(0编辑  收藏  举报