0
0

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 3 years have passed since last update.

CSSの定義方法案:セレクタとmixinによる定義方法の使い分け

Last updated at Posted at 2021-05-12

1.概要

  • CSSを作成する上での観点のメモ。
  • 設計論ではあまり言及されていない部分をプログラマー視点で考察。

(1)前提条件

  • SASSを利用してCSSを作成する。(2021年現在では、Dart-Sass+SCSSが多い)

(2)方針

  • DRY,KISSの原則に基づく。
  • 無駄な文字列を使わず、命名をできるだけ単純にする。(冗長化させない)

2.スタイルの定義方法の分類

 スタイルの定義の方法として、セレクタとmixinによる定義の2つの形式に分けられる。
 関数は、数値計算等に利用し、定義には使用しない。

(1)セレクタによる定義

  • HTML要素、id、classなどを定めて、それに対してスタイルを定義する。
  • CSSとしてユーザーのブラウザに送信される。(定義と実行を伴う)

(2)mixinによる定義

  • 独自の名前によりスタイルを定義。
  • 複数の定義をまとめるショートカットの役割がある。
  • CSSとして直接は生成されず、ブラウザにも送信されない。(定義のみで実行は伴わない)
  • 汎用的なスタイルの定義はmixinでショートカットを作成し、セレクタで使う。
  • 実際にブラウザでは利用されないため、予期しない干渉を防ぐことができる。

3.定義方法のメリット・デメリット

セレクタ

  • セレクタでの定義は、画面上に影響します。広域的に利用することで、CSSの定義数を減らすことができます。
  • 上記は、無思慮に多数の定義をつくることで予期しない影響を及ぼします。
  • セレクタ名の工夫やソースの配置を考え、できるだけ最小限の数で定義することで問題を減らすことができます。

mixin

  • 画面上に影響しないので、汎用的で些末な定義はmixinでした方が予期しない影響を抑えることができます。
  • 一方、mixinは置換になるので、CSSのサイズが増えてしまうことがあります。
  • セレクタの定義を最小限にしつつ、その中で呼び出すことにより、結果的に、トータルでは少ないコード数になります。

4.定義方法の使い所

セレクタ

  • 標準の定義方法やmixinなどの定義を複数組み合わせて、画面上の部品に対して定義をする。
_box.scss
@use "config" as c;

.g-box {
  border: solid 1px map-get(c.$color-set, "box-line-gray");
}

mixin

  • 画面上の部品ではなく、汎用的で小さい範囲のものを定義する。
  • 数行にわたるものを1行で呼び出せるようにする。
  • cssの標準ではわかりにくものに別名を与えてわかりやすくする。
_margin.scss

@mixin h-center-margin {
  margin-left: auto;
  margin-righ: auto;
}

@mixin v-center-margin {
  margin-top: auto;
  margin-bottom: auto;
}

5.最後に

セレクタとmixinをうまく使い分けることで、予期しない影響を省きつつ、かつ、ビルドされたCSSのコードサイズを抑えることができると思います。
 

0
0
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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?