2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

【SCSS / SASS】オレオレ爆速Mixins

Posted at

SASSをしばらく使ってみて、どんなプロダクトでも使うとコーディングが早くなる汎用的なMixinとクラスを発見したので共有したいと思います。

他にも「これも結構使えるテンプレだぞ!」ってやつがあったらコメントで教えていただきたいです。

リセットCSS

早速Mixinじゃないですが、僕はあんまり巷に出回るリセットCSSが好きじゃなくて、自分が最低限必要だと思って毎回使ってるリセットCSSなのでご紹介しておきます。

一番下のbackground-colorはコメントアウトを外すと要素が見やすくなります。

* {
  position: relative;
  margin: 0;
  padding: 0;
  font-feature-settings: 'palt';
  box-sizing: border-box;
  list-style-type: none;
  text-decoration: none;
  scroll-behavior: smooth;
  // background-color: rgba(255,0,0,0.05);
}

ボタンにリンクを配置するとき

とてもよく使います。ボタンをリンクにするためのMixinです。

divspanで作ったボタンをそのままaタグで囲うと、ボタンの中の文字だけがリンクになるので、ボタンの内側を全てリンクにする場合はaタグをposition: absoluteして、ボタンの内側に配置するのが一般的だと思います。

それを一々書かなくても良くしたMixinと、それを指定したクラスになります。

@mixin covered-link {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

a.covered-link {
  @include a-link;
}

以下のように書くだけで使えます。(Pugを使ってます)

.button
	span ボタン
	a.covered-link(href='#')

背景画像を設定するとき

これもとてもよく使います。

background-imageを設定するときの多くは中央寄せにしますし、繰り返ししないので、それをまとめたmixinです。要素に収まるように画像を配置するとき用のbg-containと、要素いっぱいに配置するとき用のbg-coverがあります。

@mixin bg-contain {
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

@mixin bg-cover {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

以下のように使います。

.image {
	@include bg-cover;
  width: 100px;
  height: 100px;
}

メディアクエリ

とてもよく使います。

メディアクエリを書きやすく、ブレイクポイントを変更しやすくしたものです。こちらのサイトを参考にしました。

$breakpoint-width-up: (
  'sm': '480px',
  'md': '896px',
  'lg': '1024px',
) !default;

$breakpoint-width-down: (
  'sm': '479px',
  'md': '895px',
  'lg': '1023px',
) !default;

@mixin media-width-up($breakpoint: md) {
  @if str-index($breakpoint, px) {
    @media screen and (min-width: #{$breakpoint}) {
      @content;
    }
  }
  @else {
    @media screen and (min-width: #{map-get($breakpoint-width-up, $breakpoint)}) {
      @content;
    }
  }
}

@mixin media-width-down($breakpoint: md) {
  @if str-index($breakpoint, px) {
    @media screen and (max-width: #{$breakpoint}) {
      @content;
    }
  }
  @else {
    @media screen and (max-width: #{map-get($breakpoint-width-down, $breakpoint)}) {
      @content;
    }
  }
}

@mixin media-height-up($breakpoint) {
  @media screen and (min-height: #{$breakpoint}) {
    @content;
  }
}

@mixin media-height-down($breakpoint) {
  @media screen and (max-height: #{$breakpoint}) {
    @content;
  }
}

以下のように使います。横の長さはsm/md/lgでもpxでも指定できますが、縦の長さはpxでしか指定できないようにしています。

p {
  // 画面の幅がsm以下の場合に適用
  @include media-width-down(sm) {
    color: yellow;
  }
  // 画面の幅が600px以上の場合に適用
  @include media-width-up(600px) {
    color: white;
  }
  // 画面の縦の長さが1000px以下の場合に適用
  @include media-height-down(300px) {
    color: red;
  }
}

〇〇px以下で出現/消える要素

割とよく使うし、頼りになります。このMixinは上のメディアクエリに依存するので、使用するときは一緒に@importしてください。

メディアクエリでどうにかなるときがほとんどですが、PC版とスマホ版で違う文字のデザインが要求されたりします。そのときに「うっ」とならずに、強引に解決してしまう方法です。あまり変な使い方をするとSEOやアクセシビリティ的にも良くないとは思いますが、開発は爆速で進みます。

@mixin visible-settings($size, $mode) {
  &.#{$size} {
    @if $mode == 'hidden' {
      @include media-width-up($size) {
        &.inline {
          display: inline;
        }
        &.inline-block {
          display: inline-block;
        }
        &.block {
          display: block;
        }
      }
      display: none;
    }
    @else {
      @include media-width-down($size) {
        &.inline {
          display: inline;
        }
        &.inline-block {
          display: inline-block;
        }
        &.block {
          display: block;
        }
      }
      display: none;
    }
  }
}

.when-less-than {
  &.hidden {
    @include visible-settings(md, 'hidden');
    @include visible-settings(sm, 'hidden');
  }
  &.appear {
    @include visible-settings(md, 'appear');
    @include visible-settings(sm, 'appear');
  }
}

以下のように使います。

span.appear.when-less-than.sm.inline // スマホ版で表示
span.hidden.when-less-than.sm.inline-block // PC/タブレット版で表示

注意点として、このクラスを指定した要素にはdisplayを上書きしないでください。

フォントが混ざらないようにするとき

まあまあ使います。

フォントを指定するときは英語専用のフォントを優先的に指定して、日本語のときはその他のフォントを指定することがほとんどですが、日本語の中に英語が混じることになります。それが困るときに、このMixinを使用して、日本語のみのフォントを指定します。

@mixin font-family($lang) {
  @if $lang == ja {
    font-family: 'Noto Sans JP', sans-serif;
  } @else {
    font-family: 'Apple LiGothic Medium', 'Roboto', 'Noto Sans JP', sans-serif;
  }
}

以下のように使います。

p.only-japanese {
  @include font-family(ja);
  font-size: 14px;
}

activeで出現するやつ

たまに使います。

JavaScriptでクラスをいじって、.activeが付いている間だけ出現するやつです。

@mixin on-active-appear {
  opacity: 0;
  pointer-events: none;
  transition: opacity .5s;
  &.active {
    opacity: 1;
    pointer-events: auto;
  }
}

以下のように使います。

.login-button {
  @include on-active-appear
}
.login-button //- 見えない
.login-button.active //- 見える

隠しテキストを置くとき

SEOへの配慮も含めて、隠しテキストを置くときはよくあります。背景画像を使ったときの代替テキストや、section始めの区切りとしておくことがあります。apple.comで同様のテクニックが使われていたので、やっておくといいことがあると思います。display:noneはしないのがポイントだと思われます。

@mixin visibility-hidden {
  position: absolute;
  overflow: hidden;
  width: 1px;
  height: 1px;
}

.visibility-hidden {
  @include visibility-hidden
}

以下のように使います。

.h2
	span.dog-image //- 犬の画像
	span.visibility-hidden Dog //- Dogというテキストを置いておく。
2
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?