Web制作をしていると、

最新のCSS機能を使いたいけど、未対応のブラウザがあるせいで使えない…
という経験がある人も多いのではないでしょうか。
特にIEや古いバージョンのブラウザでは、新しめのCSSプロパティがサポートされていないということが頻繁にありますよね。
今回の記事では、ブラウザが特定のCSSプロパティに対応しているかどうかを判別する@supports
の使い方を紹介します!
この機能を使用することで、
- 対応済みのブラウザにのみ最新のCSSを適用
- 対応していないブラウザにはフォールバックのコードを適用
というふうに振り分けることができます。
実際に例を見つつ説明していきますので、ぜひ使ってみてください。
@supportsの構文・記述方法
まずは構文から見ていきましょう。
@supports (display: grid) { /* display:gridに対応しているかどうか判別 */
/* 対応しているブラウザにのみ、このコードが適用される */
div {
display: grid;
}
}
メディアクエリと同じような構文ですね。
この例では、display: grid
に対応しているブラウザにのみ、{}内のコードが適用されます。
また、not
を足すことで、「〜がサポートされていない場合、{}内のコードを適用する」という書き方もできます。
@supports not (display: grid) { /* display:gridに対応しているかどうか判別 */
/* 対応していないブラウザにのみ、このコードが適用される */
div {
float: right;
}
}
この場合だと、display: grid
がサポートされていないブラウザでは、float: right
を使うという意味になります。
@supportsのブラウザ対応状況

見てのとおり、IE以外のブラウザではほぼ対応されていますね。
IEにはフォールバックのコードを適用させ、モダンブラウザには@supports
内のCSSコードを適用させるといった使い方ができます。
@supportsの実際の使い方を解説
ここからは実際に@supports
の使い方を見ていきましょう。
例として、比較的新しめのCSSプロパティmix-blend-mode
を使用して進めていきます。
CSSプロパティmix-blend-modeについて
mix-blend-mode
は、重なった図形や写真の色を混ぜ合わせることができるプロパティです。

上記の通り、IEやその他一部のブラウザではサポートされていませんね。
- 対応済みのブラウザ…mix-blend-modeを適用
- 未対応のブラウザ…フォールバックで対応
というのを実装していきましょう。
手順1. まずは通常通りCSSを書いていく


左が元の画像、右がmix-blend-mode
適用後の見た目です。
/* 背景画像のスタイル */
.bg {
position: relative;
width: 100%;
height: 100vh;
background: url("path/img.jpg");
background-size: cover;
background-position: center center;
background-repeat: no-repeat;
}
/* 画像に被せるオーバーレイのスタイル */
.bg::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-image: linear-gradient(to bottom, #ff6e7f 0%, #bfe9ff 100%);
mix-blend-mode: multiply;
}
上記のコードで、mix-blend-mode
が適用されました。
Google Chromeで確認すると、ブレンドモードがきれいに表示されています。

先程の表のとおり、Google Chromeはmix-blend-mode
に対応しているので、問題なく使うことができますね。
続いて、mix-blend-mode
に対応していないIEでチェックしてみましょう。

このようにmix-blend-mode
が効かず、オーバーレイのみが表示されてしまっています。
手順2. @supportsで対応ブラウザにのみmix-blend-modeを適用する
/* 画像に被せるオーバーレイのスタイル */
.bg::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-image: linear-gradient(to bottom, #ff6e7f 0%, #bfe9ff 100%);
}
@supports (mix-blend-mode: multiply) {
.bg::before {
mix-blend-mode: multiply;
}
}
上記のようにして、mix-blend-mode
を@supports
の中に移動させます。
これで対応ブラウザにのみmix-blend-mode
が適用されるようになりました。
しかし、IEではまだこの画面のような状態のままです。

疑似要素のオーバーレイが、画像の上にそのまま乗っかっている状態ですね。
次でIEや未対応のブラウザのためのフォールバックコードを用意していきましょう。
手順3. 未対応のブラウザのためのフォールバックを用意する
.bg::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
/* フォールバック */
background-image: linear-gradient(to bottom, #b10519 0%, #1d5e80 100%);
opacity: 0.5;
}
@supports (mix-blend-mode: multiply) {
.bg::before {
mix-blend-mode: multiply;
background-image: linear-gradient(to bottom, #ff6e7f 0%, #bfe9ff 100%);
opacity: 1;
}
}
未対応のブラウザではmix-blend-mode
の代わりに、オーバーレイの色を暗めにして半透明にするというフォールバックを用意しました。
opacity
プロパティは全ブラウザに対応しているので、安心して使えますね。

このように、全く同じ見た目ではないですが、IEでもほぼ同じ見た目になりました。
Google Chromeでも確認してみましょう。

先ほどと全く同じのままで、mix-blend-mode
が適用されていますね。
これらの手順で、
- 対応ブラウザでは最新のCSSプロパティmix-blend-modeを適用
- 未対応ブラウザではフォールバックを適用
ということができました。
【まとめ】@supportsで対応済みのブラウザには最新のCSS、それ以外はフォールバックを適用させる方法
@supportsを使って、ブラウザの対応状況に応じて条件分岐させる方法を紹介しました。
- CSSを通常どおり書く
- 最新のCSS機能には@supportsを使用する
- 未対応のブラウザのためのフォールバックを用意する
これらの手順で、モダンブラウザには最新のCSS機能、それ以外は代替策を使うことができるようになります。
実際ブラウザのシェアはGoogle Chrome, Safari, Firefoxなどのモダンブラウザが圧倒的に多いため、最新のCSSを使いたいですよね。
しかし案件によってはIEやマイナーなブラウザにも対応させる必要があるので、そういう場面にはすごく使える機能です。
IEのみを指定してスタイルを指定する方法も紹介してますので、よければ目を通してみてください。

コメント