演習 - CSS を使用して HTML をスタイル設定する

完了

カスケード スタイル シート (CSS) を使用して、ページの表示方法を指定できます。 基本的な考え方は、HTML ページ内で使用する要素をどのようなスタイルにするかを定義することです。 HTML 要素がコンテンツを定義するのに対し、CSS スタイルはこのコンテンツの外観を定義します。

たとえば、要素の角を丸くしたり背景をグラデーションにしたりすること、または CSS を使ってユーザーが操作するときのハイパーリンクの外観や応答方法を指定することができます。 また、高度なページ レイアウトやアニメーション効果を実行することもできます。

特定の要素や、特定の種類のすべての要素にスタイルを適用したり、クラスを使用して多くの異なる要素のスタイルを指定したりできます。

この演習では、HTML ページ要素に CSS スタイルを適用し、ライト テーマとダーク テーマを定義するための CSS コードを追加します。 次に、ブラウザーの開発者ツールで結果を確認します。

外部 CSS

HTML に関する前のユニットでは、HTML から外部 CSS ファイルにリンクしました。

...
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Task Timeline</title>
  <link rel="stylesheet" href="main.css">
...

外部 CSS の 1 つの利点は、複数の HTML ページを同じ CSS ファイルにリンクできることです。 CSS を変更した場合は、ページごとにスタイル設定が更新されます。 ページ コンテンツには HTML ファイル、スタイルの設定には CSS ファイル、対話には JavaScript ファイルを使うことを、"関心の分離" といいます。

先に説明したように、HTML に直接 CSS を記述することもできます。これは、"内部 CSS" と呼ばれます。 基本的な Web サイトの場合でも非常に多くの CSS 規則があり、HTML ページはすぐに乱雑になる可能性があります。 複数のページでは、多くの場合、同じ CSS が繰り返され、管理するのが難しくなります。

CSS 規則

CSS 規則は、HTML 要素にスタイルを適用する方法です。 CSS の規則にはセレクターがあり、スタイルを適用する必要がある (1 つまたは複数の) 要素を表すために使われます。

Visual Studio Code で、main.css ファイルを開き、以下のように入力します。

body {
    font-family: monospace;
}

ul {
    font-family: helvetica;
}

このコード スニペットには、2 つの規則が含まれています。 各規則には次のものが含まれます。

  • "セレクター"。 bodyul は 2 つの規則のセレクターであり、スタイルを適用する要素を選ぶために使われます。
  • 左中かっこ ({)。
  • 選択した要素の外観を決定するスタイルの "宣言" のリスト。
  • 右中かっこ (})。

たとえば、ul セレクターは、スタイルの適用対象としてページ内の <ul> HTML 要素を選びます。 宣言は font-family: helvetica であり、スタイルで使う必要があるものを決定します。 プロパティ名font-family で、helvetica です。

次に示すように、要素に対して独自のカスタム名を定義できます。

セレクター

ID と "クラス" セレクターを使うと、HTML 内のカスタム属性名にスタイルを適用できます。 1 つの要素にスタイルを適用するには ID を使い、複数の要素にスタイルを適用するにはクラスを使います。

  1. 次のコードをコピーし、CSS ファイルに追加します。 これを、先ほど追加した ul セレクターの閉じ中かっこの後に貼り付けます。

    li {
      list-style: circle;
    }
    
    .list {
      list-style: square;
    }
    
    #msg {
      font-family: monospace;
    }
    

    上記のコードには 3 つの CSS 規則が含まれており、最後の 2 つの規則ではカスタム属性を使用して要素 .list#msg が選択されています。

    • .list は "クラス セレクター" です。 list に設定された class 属性を含む各 HTML 要素は、このセレクターで定義されているスタイルを取得します。

    • #msg は "ID セレクター" です。 id 属性が msg に設定されている HTML 要素は、このセレクター内で定義されているスタイルを取得します。

    セレクターに使用する名前は、HTML で定義されているものに一致している限り、任意の名前にすることができます。

  2. Windows の Ctrl + S キーまたは macOS の Command + S キーを選択して、作業内容を保存します。

ブラウザーで表示

  1. Visual Studio Code を使ってプレビューするには、エクスプローラーで index.html ファイルを右クリックして、[既定のブラウザーで開く] を選びます。

    重要

    main.css ファイルを編集するだけであっても、変更をプレビューするには、index.html ファイルを選択する必要があります。

    既定のブラウザーで Web ページが開きます。

    フォント スタイルが適用された Web サイトのスクリーンショット。

フォント スタイルは期待どおりになっていますか。 <body> に適用されたスタイルは、興味深い方法で <h1> 要素に継承されます。 <h1> に対しては何も定義しませんでしたが、それでも <body> で定義されているフォントを取得しました。 親要素から子孫へのこの継承メカニズムは、CSS の重要な側面の 1 つです。 ただし、<li> 要素のフォントは異なります。 <li> 要素は、スタイルを定義した <ul> 要素の子孫であるため、<li> 要素のスタイルは <body> に設定したスタイルをオーバーライドします。

Visual Studio Code で [既定のブラウザーで開く] を使うと、毎回ブラウザーで新しいタブが開きます。 新しいタブが開かないようにするには、代わりに Web サイトが既に含まれているタブを再度読み込みます。

タブを再度読み込むには、表示更新のキーボード ショートカットである F5 キーを押すか、Windows または Linux では Ctrl + R キー、Mac では Command + R キーを押します。

ライト テーマを追加する

次に、Web サイトの配色テーマのサポートを追加します。 まず、16 進カラー コードを使用して明るい色のテーマを定義します。

  1. CSS ファイル (main.css) で、ファイルの末尾に次のコードを追加します。

    .light-theme {
      color: #000000;
      background: #00FF00;
    }
    

    この例では、#000000 がフォントの色の黒を指定し、#00FF00 が背景色の緑を指定します。

  2. HTML ファイル (index.html) で、<body> 要素をクラス名 light-theme で更新します。 これで、ライト テーマのクラス セレクターを使ってスタイルが正しく適用されるようになりました。

    <body class="light-theme">
    

ブラウザーで表示

  • Visual Studio Code を使ってプレビューするには、index.html を右クリックして [既定のブラウザーで開く] を選ぶか、F5 キーを押して前のタブを再度読み込みます。

    背景が緑色のライト テーマが表示されていることがわかります。

    ライト テーマが適用された Web サイトのスクリーンショット。

適用された CSS を表示する

  1. ブラウザー ビューで、開発者ツールを開きます。

    ページを右クリックして [検査] を選ぶか、ショートカットの F12 キーまたは Ctrl + Shift + I キーを押します。

  2. [要素] タブを選んでから、[要素] タブの内部にある [スタイル] タブを選択します (既定で既に選ばれているはずです)。

  3. さまざまな HTML 要素をポイントして選択し、それらにどのスタイルが適用されるかが開発者ツールの [スタイル] タブにどのように表示されるかに注目してください。

  4. <body> 要素を選択します。 light-theme が適用されていることに注目してください。

  5. 順序のないリストである <ul> 要素を選択します。 カスタム スタイル font-family: helvetica; に注目してください。<body> 要素のスタイルがオーバーライドされています。

ライト テーマが適用された Web サイトと、その横の開発者ツールの要素パネルに HTML と CSS のコードが表示されているスクリーンショット。

開発者ツールでの CSS スタイルの表示の詳細については、「CSS の表示と変更の概要」を参照してください。

ダーク テーマを追加する

ダーク テーマの場合は、Web ページ上でのテーマの切り替えを有効にする次のユニットに備えて、インフラストラクチャを設定します。

CSS にダーク テーマのサポートを追加するには、次の手順を使用します。

  1. CSS ファイル (main.css) で、ファイルの先頭のページ ルートにいくつか定数を追加します。

    :root {
      --green: #00FF00;
      --white: #FFFFFF;
      --black: #000000;
    }
    

    :root セレクターは、HTML ページの <html> 要素を表します。 この種のタスクでのベスト プラクティスは、CSS 規則で :root セレクターを使用してグローバル CSS 変数のセットを定義することです。 この例では、3 つの色変数を定義しています。 これで、これらの変数を他の CSS 規則で使用できるようになりました。

  2. CSS ファイルの末尾で、light-theme 規則を次のコードに置き換えて更新し、dark-theme セレクターを追加します。

    .light-theme {
      --bg: var(--green);
      --fontColor: var(--black);
    }
    .dark-theme {
      --bg: var(--black);
      --fontColor: var(--green);
    }
    

    上記のコードでは、背景とフォントの色を指定する 2 つの新しい変数 bgfontColor を定義しています。 これらの変数では、var キーワードを使用して、:root セレクターで前に指定した変数にプロパティ値を設定します。

  3. 次に、CSS ファイルで、現在の body セレクターを次のコードに置き換えます。

    body {
      background: var(--bg);
      color: var(--fontColor);
      font-family: helvetica;
    }
    

    この例では、body セレクターを使って background および color プロパティを設定しており、Web ページに表示される要素はすべて <body> 要素内にあるため、<body> で設定されている色を継承します。

  4. CSS ファイルで、同じフォントを <body> から継承するように、#msg および ul セレクターを含む規則を削除します。

  5. 忘れずに Ctrl + S キーまたは Command + S キーを押してファイルを保存してください。

    これで CSS ファイル (main.css) は次の例のようになるはずです。

    :root {
      --green: #00FF00;
      --white: #FFFFFF;
      --black: #000000;
    }
    
    body {
      background: var(--bg);
      color: var(--fontColor);
      font-family: helvetica;
    }
    
    li {
      list-style: circle;
    }
    
    .list {
      list-style: square;
    }
    
    .light-theme {
      --bg: var(--green);
      --fontColor: var(--black);
    }
    
    .dark-theme {
      --bg: var(--black);
      --fontColor: var(--green);
    }
    
  6. ダーク テーマを表示するには、ファイル index.html を開き、<body> クラス属性の既定のテーマを手動でダーク テーマ (dark-theme) に編集します。 ファイルを保存し、ブラウザーでページを再度読み込みます。

    ダーク テーマが適用された Web サイトと、その横の開発者ツールのスクリーンショット。

  7. <body> クラス属性を編集して、既定値をライト テーマに戻します。

次のユニットでは、JavaScript を使って対話機能を提供し、テーマの切り替えをサポートします。