1. 程式人生 > >sass 常用用法筆記

sass 常用用法筆記

本文轉載於:猿2048網站sass 常用用法筆記

最近公司開發的h5專案,需要用到sass,所以領導推薦讓我去阮一峰大神的SASS用法指南部落格學習,為方便以後自己使用,所以在此記錄。

一、程式碼的重用

  1、繼承:SASS允許一個選擇器,繼承另一個選擇器。

    class2要繼承class1,就要使用@extend命令:

.class1 {
    border: 1px solid #ddd;
}
.class2 {
    @extend .class1;
    font-size:120%;
}

  2、Mixin:Mixin有點像C語言的巨集(macro),是可以重用的程式碼塊。

    使用@mixin命令,定義一個程式碼塊。使用@include命令,呼叫這個mixin。

  @mixin left {
    float: left;
    margin-left: 10px;
  }
  div {
    @include left;
  }

    mixin的強大之處,在於可以指定引數和預設值。使用的時候,根據需要加入引數:

   @mixin left($value: 10px) {
    float: left;
    margin-right: $value;
   }
  div {
    @include left(20px);
  }

  3、顏色函式

  SASS提供了一些內建的顏色函式,以便生成系列顏色。

   lighten(#cc3, 10%) // #d6d65c
  darken(#cc3, 10%) // #a3a329
  grayscale(#cc3) // #808080
  complement(#cc3) // #33c

  4、插入檔案

  @import命令,用來插入外部檔案

@import "path/filename.scss";

二、高階用法

1、條件語句:

  @if可以用來判斷

   p {
    @if 1 + 1 == 2 { border: 1px solid; }
    @if 5 < 3 { border: 2px dotted; }
  }

  配套的還有@else命令:

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

2、迴圈語句

  for迴圈:

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

  while迴圈:

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

  each命令,作用與for類似:

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

3、自定義函式

  SASS允許使用者編寫自己的函式。

 @function double($n) {
    @return $n * 2;
  }
  #sidebar {
    width: double(5p