オーダーメイドコース
icon
icon

CSSクラス間の継承方法を現役エンジニアが解説【初心者向け】

初心者向けにCSSクラス間の継承方法について解説しています。親要素で指定されたスタイルが子要素にも適用されることを継承といいます。継承されるスタイルの内容、inheritを使って強制的に継承する方法について学びましょう。

テックアカデミーマガジンは受講者数No.1のプログラミングスクール「テックアカデミー」が運営。初心者向けにプロが解説した記事を公開中。現役エンジニアの方はこちらをご覧ください。 ※ アンケートモニター提供元:GMOリサーチ株式会社 調査期間:2021年8月12日~8月16日  調査対象:2020年8月以降にプログラミングスクールを受講した18~80歳の男女1,000名  調査手法:インターネット調査

CSSクラス間の継承方法について、TechAcademyのメンター(現役エンジニア)が実際のコードを使用して初心者向けに解説します。

 

CSSについてそもそもよく分からないという方は、CSSの書き方について解説した記事をみてみましょう。

 

なお本記事は、TechAcademyのオンラインブートキャンプ、Webデザイン講座のCSSカリキュラムをもとに執筆しています。

 

田島悠介

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

大石ゆかり

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

田島悠介

クラス間の継承方法について詳しく説明していくね!

大石ゆかり

お願いします!

 

目次

 

スタイルの継承について

親要素に適用したスタイルが子要素にも適用されることをスタイルの継承と呼びます。

CSSで1つ1つの要素にスタイルを適用するのは手間がかかるので、スタイルの継承を上手に利用しながらCSSを作成していくのがデザインのポイントです。

 

[PR] Webデザインで副業する方法とは

継承される相対的な単位と注意点

継承される要素同士は親子関係である必要があります。

子要素は直下の要素だけでなく、孫要素やひ孫要素も含みます。

 

継承されるスタイルは属性によることに注意が必要です。

継承されるスタイルの例として、背景色やフォントサイズも含まれます。

しかし、継承されないスタイルの例としては、枠線などが含まれる点には注意が必要です。

.parent {
  background: pink;  /* 継承される */
  font-size: 3rem; /* 継承される */
  border: solid 2px red; /* 継承されない */
}

 

強制的に継承する方法

継承しない属性であってもinheritキーワードを指定することで強制的に継承することができます。

.child {
  border: inherit;
}

 

 

クラス間で継承していることを見てみよう

今回のサンプルプログラムでは、親子関係の要素で継承が行われていることを確認しましょう。

ブラウザはChromeを使用しています。

index.html

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .parent {
        background: pink;
        width: 200px;
        border: solid 2px red;
        padding: 10px;
        font-size: 3rem;
      }

      .child {
      }
    </style>
  </head>
  <body>
    <div class="parent">
      親要素です
      <div class="child">子要素です</div>
    </div>
  </body>
</html>

実行結果は以下のとおりです。

Chromeのデベロッパーツールで継承が行われていることを確認しましょう。

要素選択ボタンで子要素を選択すると、.parentクラスが適用されていることが確認できます。

 

まとめ

今回の記事ではCSSクラス間の継承方法について学習しました。

継承されるものとそうでないものがあるため、注意が必要です。

 

執筆してくれたメンター

太田和樹(おおたかずき)

ITベンチャー企業のPM兼エンジニア

普段は主に、Web系アプリケーション開発のプロジェクトマネージャーとプログラミング講師を行っている。

守備範囲はフロントエンド、モバイル、サーバサイド、データサイエンティストと幅広い。

その幅広い知見を生かして、複数の領域を組み合わせた新しい提案をするのが得意。

開発実績:画像認識技術を活用した駐車場混雑状況把握、音声認識を活用したヘルプデスク支援システム、ロボットアプリの開発、大規模基幹系システムの開発・導入マネジメント。

著書「知識ゼロからの機械学習入門(技術評論社)」。

地方在住。

仕事のほとんどをリモートオフィスで行う。

通勤で消耗する代わりに趣味のDIYや家庭菜園、家族との時間を楽しんでいる。

 

大石ゆかり

CSSクラス間の継承方法がよく分かったので良かったです!

田島悠介

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

大石ゆかり

分かりました。ありがとうございます!

TechAcademyでは初心者でも、オリジナルWebサイトを公開できる、オンラインブートキャンプを開催しています。

また、現役エンジニアから学べる無料体験も実施しているので、ぜひ参加してみてください。