SCSS 基本チートシート

 SCSS の便利さに感動した。

コンパイルコマンド

# ファイルごと
$ sass scss/base.scss:css/base.css
# ファイルごと(インデントなし)
$ sass --style expanded scss/base.scss:css/base.css
# フォルダごと監視
$ sass --style expanded --watch scss:css

ファイル分割

// _test-base.scss
@import "test-base";

基本

// 変数
$baseFontSize: 12px;
$baseImgDir: "../img/";
$baseFontColor: #808080;

#text {
  width: 300px;
  // #{} は内部を展開する
  background: url("#{$baseImgDir}bg.png");
  font-size: $baseFontSize;
  color: $baseFontColor;
  p {
    // 計算式を書くことも可能
    font-size: $baseFontSize - 2px;
    // darken も存在する
    color: lighten($baseFontColor, 30%);
    a {
      // & は親要素を表す
      &:hover {
        font-weight: bold;
      }
    }
  }
}

条件分岐

@function test($number: 1) {
  @if $number == 1 {
    @return 5;
  }
  @else if $number == 100 {
    @return 10;
  }
  @else {
    @return 15;
  }
}

#test-1 {
  padding: test();
}
$number: 100;
#test-100 {
  padding: test($number);
}
$number: 1000;
#test-else {
  padding: test($number);
}

ループ

$baseFontColor: #66cdaa;
@for $i from 1 through 5 {
  $darkenNum: ($i * 10);
  .color-#{$i} { color: darken($baseFontColor, $darkenNum) }
}

$baseFontColor: #000000;
$i: 1;
@while $i <= 10 {
  $rgbaNum: ($i * 0.1);
  .rgba-#{$i} { color: rgba($baseFontColor, $rgbaNum) }
  $i: $i + 1;
}

リスト

$baseIconDir: "../img/icons/";
$icons: page, arrow, book;
@each $iconName in $icons {
  .#{$iconName}-icon { background: url("#{$baseIconDir}#{$iconName}.png"); }
}

設定定義

@mixin circle {
     border-radius: 100%;
}
.box1 {
     @include circle;
}

継承

.message {
  font-size: 14px;
  font-weight: bold;
}
.errorMessage {
  @extend .message;
  color: #ff0000;
}
.warningMessage {
  @extend .message;
  color: #ffff00;
}