CSSで変数(カスタムプロパティ)を使ってみよう

プログラミングではおなじみの変数。SassやLESSといったCSSプリプロセッサーをお使いの方もよく使うものですね。この一度定義しておけば繰り返し利用できる便利な変数が、CSSでも使えるようになりました!今回はCSS変数(カスタムプロパティ)の使い方と注意点をまとめていきます!

↑私が10年以上利用している会計ソフト!

CSSカスタムプロパティとは?

公式では「カスケード変数のためのCSSカスタムプロパティ(CSS custom properties for cascading variables)」としていますが、単に「CSSカスタムプロパティ」や「CSS変数」などとも呼ばれています。

変数は文字列や数値などを入れる箱のようなものです。例えば数学では「y = 3x」のような式があり、この y や x の中には自由に数字を当てはめられます。これが変数というものです。数学では数値のみ使えましたが、プログラミングの世界では文字列も含められます。そしてその中身の入った箱は何度も繰り返し利用でき、箱の中身が変わると他の箇所も変更されるという仕組みです。

何度も繰り返し利用する数値やカラーコードなどにCSSカスタムプロパティを使えば、仮に変更することがあったとしてもすべての箇所を修正する必要はなく、最初に定義しておいたカスタムプロパティの中身だけ変えればOK!メンテナンスがしやすくなり、エラーも少なくなります。

CSSカスタムプロパティの使い方

1. CSSカスタムプロパティの定義

まずはカスタムプロパティの定義です。「この箱にはこの値が入ってるよー!」という宣言をします。各セレクターに記述することもできますが、:root に定義してグローバル変数のように使用できます。

カスタムプロパティの宣言には -- から始め、続いてカスタムプロパティの名前(好きなものでOK)を書きます。コロンで区切ってカスタムプロパティの値を記述。この値が呼び出されるようになります。

カスタムプロパティはカラーコードだけではなく、単位のついた数値や文字列も設定できます。

例:

:root {
  --main-gutter: 12px;
  --main-position: center;
  --main-lh: 1.5;
}

2. 定義したCSSカスタムプロパティを呼び出す

実際に使いたい箇所で var(--変数名) と記述すると、定義した値を当てはめられます。

例:

:root {
  --main-gutter: 30px;
}
.box {
  width: 300px;
  height: 100px;
  margin: var(--main-gutter);
}

この例だと .box という要素に margin: 30px; が加わります。

See the Pen CSS Variables Basic by Mana (@manabox) on CodePen.

様々な場面でCSSカスタムプロパティを使ってみよう

CSSカスタムプロパティは、一度定義しておけば、あとは好きなところで呼び出して使う!というだけのシンプルなもの。でもそれだけじゃ物足りないので、「こんな時にも使えるよ!」というのをまとめてみます。

カスタムプロパティの中でカスタムプロパティを使う

例えばカスタムプロパティで色を定義した後、その色を使ったカスタムプロパティも定義できます。

CSS

:root {
  --main-color: #7117ea;
  --sub-color: #ea6060;
  --bg-gradation: linear-gradient(135deg, var(--main-color) 0%, var(--sub-color) 100%) fixed;
}
body {
  background: var(--bg-gradation);
}

この例ではまず --main-color--sub-color で二色を設定。そして --bg-gradation でグラデーションを作る値を作成し、その中に --main-color--sub-color を盛り込んでいます。呼び出す時のコードがとってもシンプル!

See the Pen CSS Variables and Gradation Colours by Mana (@manabox) on CodePen.

こんな感じでグラデーションが設定できました。

メディアクエリーとCSSカスタムプロパティ

「CSSでカスタムプロパティ使わず、普通にSassで使えばいいやんけ!」という声がチラホラ聞こえてきます。Sassはとっても便利で、私もいつも使っています。昔Sassについての記事も書きましたね…!

ですが、SassやLESSなどのCSSプリプロセッサーの変数はCSSに変換されるため、ブラウザー幅の可変には対応できないのです。メディアクエリー内で変数を定義はできません。

Sass

$bg: pink;

@media (max-width: 600px) {
  $bg: yellow;
}

body {
  background: $bg;
}

例えば上記のコードでは基本の背景色をピンクに、600px以下の幅になると黄色にしたい、という内容ですが、実際には黄色にはなりません。$bg: yellow; という変数は無効となります。

See the Pen Media Queries and Sass Variables : Invalid! by Mana (@manabox) on CodePen.

デモ画面右上「Edit on CODEPEN」をクリックしてデバイスの幅を変更してみてください。黄色にはならずピンクのままです。

代わりにCSSカスタムプロパティを使ってみましょう。

CSS

:root {
  --bg: pink;
}
@media (max-width: 600px) {
  :root {
    --bg: yellow;
  }
}

body {
  background: var(--bg);
}

See the Pen Media Queries and CSS Variables by Mana (@manabox) on CodePen.

この書き方だとメディアクエリー内で再定義した --bg: yellow; が有効なので、600px以下の幅では背景色が黄色になります。こちらも上記デモで確認してみてください!

JavaScriptとCSSカスタムプロパティ

CSSカスタムプロパティが動的に利用できるので、JavaScriptでも活用できます。JavaScriptでCSSカスタムプロパティの値を取得したい場合はこんな感じ:

const boxElement = document.querySelector('.box');
const cssStyle = getComputedStyle(boxElement);
const cssValue = String(cssStyle.getPropertyValue('--default-position')).trim(); 

console.log(cssValue);

getPropertyValue でカスタムプロパティの値を取得できます。

JavaScriptでカスタムプロパティの値を変更したい時は setProperty が使えます:

document.documentElement.style.setProperty('--default-position', '50px');

組み合わせてあれこれできそうな予感!この辺はまたさらに深掘りしてみたいです。

CSSカスタムプロパティが取得できなかった時のフォールバック

CSSカスタムプロパティではフォールバックを記述できます。フォールバック値を記述しておくと、CSSカスタムプロパティが宣言されていなかったり、無効になってしまった時のために代わりの値が適用できます。

CSS

.box {
  color: var(--my-color, pink);
}

この場合、カスタムプロパティ --my-color が無効の場合、pink が適応されます。

CSSカスタムプロパティを使う時の注意点

CSSカスタムプロパティを使う時のルールも覚えておきましょう。こんな場合は無効になるので注意が必要です!

CSSカスタムプロパティでは大文字と小文字が区別される

たとえば、--var--VAR は別のCSSカスタムプロパティとみなされます。

CSS

:root {
  --bg: pink;
  --BG: orange;
}

これらは別のカスタムプロパティなので、var(--bg); とすればピンクが、var(--BG); とすればオレンジが適用されます。

プロパティ名をカスタムプロパティにできない

CSSカスタムプロパティには値のみが利用できます。プロパティ名をカスタムプロパティにすることはできません。

CSS

body {
  --bg: background-color;
  var(--bg): pink;
}

この書き方で background-color: pink; の指定はできません。無効となります。

呼び出す時に(単純に)単位を書き足しても無効となる

数値のカスタムプロパティを定義し、呼び出す時 var(--変数名) の後ろに px% を書き足しても無効となります。

CSS

div {
  --gutter: 30;
  margin: var(--gutter)px;
}

この例だと margin: 30px; とはなりません。カスタムプロパティに --gutter: 30px; として単位も含めておく必要があります。

CSS

div {
  --gutter: 30px;
  margin: var(--gutter);
}

↑これならOK!

また、calc() 関数を使って単位を含めることも可能です。

CSS

div {
  --gutter: 30;
  margin: calc(var(--gutter) * 1px);
}

1px など、1を掛けることで単位をプラスする技ですね!

対応ブラウザー


CSSカスタムプロパティの対応ブラウザーはChrome, Firefox, Safari, Edge等です。IE以外のモダンブラウザーには対応しているので、これからCSSカスタムプロパティを使う機会はどんどん増えてくるでしょう。


みなさんもぜひ試してみてくださいね!

参照リンク

シェアする

ニュースレター

Web制作の最新情報やWebクリエイターボックスからのお知らせ、中の人の近況等を定期的にお送りいたします。 ぜひご登録ください!もちろん無料です! :)