CSSだけでif文のような条件分岐を実装する方法を現役エンジニアが解説【初心者向け】
初心者向けにCSSだけでif文のような条件分岐を実装する方法について解説しています。他言語での条件分岐の例、CSSセレクタや否定擬似クラスを使用した実装のやり方を説明します。サンプルコードで動作を試してみましょう。
テックアカデミーマガジンは受講者数No.1のプログラミングスクール「テックアカデミー」が運営。初心者向けにプロが解説した記事を公開中。現役エンジニアの方はこちらをご覧ください。 ※ アンケートモニター提供元:GMOリサーチ株式会社 調査期間:2021年8月12日~8月16日 調査対象:2020年8月以降にプログラミングスクールを受講した18~80歳の男女1,000名 調査手法:インターネット調査
CSSだけでif文のような条件分岐を実装する方法について、TechAcademyのメンター(現役エンジニア)が実際のコードを使用して初心者向けに解説します。
CSSについてそもそもよく分からないという方は、CSSの書き方について解説した記事をまずご覧ください。
なお本記事は、TechAcademyのオンラインブートキャンプ、Webデザイン講座のCSSカリキュラムをもとに執筆しています。

今回は、CSSに関する内容だね!

どういう内容でしょうか?

CSSだけでif文のような条件分岐を実装する方法について詳しく説明していくね!

お願いします!
目次
条件分岐とは
条件分岐とはプログラミング言語の制御構文の1種で、なんらかの条件に基づいて処理を切り分けるものです。
一般的なプログラミングで使われるif文について
例えばJavaScriptでは条件分岐はif文で記述します。
const i=0;
if(i==0){
console.log('iは0です');
} else {
console.log('iは0ではありません');
}
上記の場合、変数iの値が0の場合とそうではない場合で条件分岐を行っています。上記の場合は変数の値は0であるため「iは0です」と出力されます。
CSSで条件分岐を実装するには
CSSで条件分岐を実装するにはCSSセレクタや否定擬似クラス(:not())を活用しましょう。例えば「divで選択されている要素」という条件を表現するには以下のように表記します。
div:active {
/* 適用するCSS */
}
逆に「divで選択されていない要素」は以下のように表現できます。
div:not(:active) {
background-color: pink;
}
上記のようにCSSセレクタを組み合わせることで様々な表現が可能です。擬似クラスも活用するとさらに多彩な表現が可能となります。擬似クラスについて、詳しくは以下の記事も参考にしてください。
条件分岐を実装してみよう
今回のサンプルプログラムではCSSセレクタを使った条件分岐の実装方法について確認します。
index.html
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Sample</title>
<style>
.parent {
background-color: lightblue;
width: 20vw;
height: 10vw;
padding: 1vw;
}
.child {
border: solid 2px green;
width: 90%;
height: 40%;
}
.parent :not(:active) {
background-color: pink;
}
</style>
</head>
<body>
<div class="parent">親要素
<div class="child" id="child1">子要素1</div>
<div class="child" id="child2">子要素2</div>
</div>
</body>
</html>
実行結果は以下のとおりです。子要素の中で選択されていない要素の背景色がピンクになります。条件をいろいろと変えて試してみましょう。

まとめ
今回の記事ではCSSだけでif文のような条件分岐を実装する方法について学習しました。
監修してくれたメンター
| 太田和樹(おおたかずき)
ITベンチャー企業のPM兼エンジニア 普段は主に、Web系アプリケーション開発のプロジェクトマネージャーとプログラミング講師を行っている。守備範囲はフロントエンド、モバイル、サーバサイド、データサイエンティストと幅広い。その幅広い知見を生かして、複数の領域を組み合わせた新しい提案をするのが得意。 開発実績:画像認識技術を活用した駐車場混雑状況把握、音声認識を活用したヘルプデスク支援システム、ロボットアプリの開発、大規模基幹系システムの開発・導入マネジメント。著書「知識ゼロからの機械学習入門(技術評論社)」。 地方在住。仕事のほとんどをリモートオフィスで行う。通勤で消耗する代わりに趣味のDIYや家庭菜園、家族との時間を楽しんでいる。 |

内容分かりやすくて良かったです!

ゆかりちゃんも分からないことがあったら質問してね!

分かりました。ありがとうございます!
TechAcademyでは初心者でも、オリジナルWebサイトを公開できる、オンラインブートキャンプを開催しています。
また、現役エンジニアから学べる無料体験も実施しているので、ぜひ参加してみてください。