Quantcast
Channel: CSSタグが付けられた新着記事 - Qiita
Viewing all articles
Browse latest Browse all 8669

CSSで華やかなサイトにしたい①~CSS適用方法と基礎文法~

$
0
0

CSSとは?

CSSとは、簡単に言うとHTMLを飾り付けしてくれるものです:relaxed:
Webページは華やかなほうがいいですようね?
HTMLのみのサイトだと、Webサイトは白い背景、黒い文字だけになってしまいます。
CSSでは色や文字の大きさだけではなくレイアウトも自由に変える事ができます:bangbang:

1つ例を見てみましょう。以下のポートフォリオサイトのCSSをオフするとどうなるでしょうか…
image.png
https://github.com/Yuriko-Y/myportfolio1
(Githubにコード載せてます)
:arrow_down:

image.png
驚くほど殺風景ですね…HTML自体はとてもシンプルなものだったんですね…
逆に言えばシンプルなものでも、デザイン次第では、人の目を引き付けられるサイトを作れるということです:heart_eyes:

今回の記事:arrow_down:

  • CSS適用方法
    • CSSファイルを読み込む方法
    • HTMLファイルの<head>内にCSSを書き込む方法
    • HTMLタグに直接CSSを書き込む方法
  • CSSの基本的な書き方
    • CSSの「セレクタ」とは
    • CSSの「プロパティ」とは
    • CSSの「値」とは
  • class属性とid属性とは?
    • class属性とid属性の違いと、使い分け方法

HTMLの基礎からを学びたい人:point_down_tone2:

CSS適用方法

CSSを適応させる方法は3つあります。
css.png

1つ目は、「.css」の拡張子が付いたCSSファイルを作成し、それをHTMLに読み込ませる方法。
2つ目はHTMLファイルの<head>内にCSSを書き込む方法。
3つ目はHTMLタグに直接CSSを書き込む方法です。
特別な理由がない限り、1つ目のCSSファイルを読み込む方法が良いでしょう。

CSSファイルを読み込む方法

CSSファイルを別に作り、読み込む方法です。

以下の記事を参考にCSSファイルを作ってみましょう:point_down_tone2:
CSSで見た目の調整をしよう!

HTMLファイルにCSSのファイルを読み込ませる方法は<head>タグの中に<link>タグを書きます。
コメント 2020-03-01 125523.png

index.html
<linkrel="stylesheet"href="">

herfの中にCSSのファイルがある場所を書きます。
1つのCSSファイルを複数のHTMLで読み込むことができるので、複数のHTMLファイルに対して共通のCSSを適用できます。

HTMLファイルの<head>内にCSSを書き込む方法

次にHTMLファイルの<head>内にCSSを書き込む方法です。ファイルに分ける必要もないような細かい修正を行う際に使用します。

以下のようにstyleタグを使用して、styleタグ内にcssを記入していきます。
コメント 2020-04-05 103148.png

<head>タグ内
<style>h1{color:red;}</style>

このようにh1の部分だけcssが適応されました。
image.png

HTMLタグに直接CSSを書き込む方法

HTMLのタグの中にCSSを直接CSSを書く方法です(「インラインにCSSを書く」と言ったりもします)
タグの中にCSSを書くときは、<タグ名 style="CSSをここに書く">という形になります。

コメント 2020-04-05 105129.png

インラインにCSSを書く
<h1style="color: red;">猫の一日</h1>

先ほどと同じ結果になりました!
image.png

CSSの基本的な書き方

CSSの基本的な構成と文法を見ていきます。
セレクタ.png
CSSの基本文法の書き方としては「セレクタ(どれの)」「プロパティ(何を)」「値(どのように)」変えるかを指定します。

CSS
h1{color:red;font-size:50px;}

このようにプロパティを改行して何個も書くことができます。この場合を日本語で解説すると、
「セレクタ(h1の)」
「プロパティ(色を)」「値(赤に)」、また
「プロパティ(フォントの大きさを)」「値(50pxに)」したとなります。

CSSの「セレクタ」とは

CSSのセレクタはどの対象物を変化させるかを指定します。一番簡単なセレクタはHTMLのタグです。
例えば、h1やpタグ、divタグなどです。
しかし、h1やpタグが同じHTMLファイルにたくさんあり、それぞれ適応させたいCSSを変えたいときは「子孫セレクタ(しそん)」を使います。これは、「どこの中にある何」という指定の仕方ができます。

子孫セレクタの例
divh1{color:red;}

この場合だとdivタグの中のh1だけ色が変わります。

CSSの「プロパティ」とは

「プロパティ」とはセレクタで指定した物の「どの内容を変えるのか」を指定するものです。
代表的なものをを以下の表にまとめてみました。

プロパティ意味
color
font-size文字サイズ
width横幅
height高さ
background-color背景色
font-weight文字の太さ

CSSの「値」とは

「セレクタとプロパティ」で指定したものに対して「どのように変える」かを指定するものです。
値はプロパティによって様々なものがあります。
例えば、プロパティが色なら、値は何色にするかという値が入り、プロパティが文字サイズなら、値は大きさを表す数字と単位を入れる必要があります。

class属性とid属性とは?

これでだいぶCSSの基本的な書き方がわかってきたのではないでしょうか:yum:

ではこの場合はどうでしょう。
以下のコードがありました。

<div><h1>猫の一日</h1><p>ひたすら寝てます</p></div><div><h1>猫の遊び</h1><p>猫じゃらしで遊びます。</p></div>

divタグで囲まれた塊が二つあり、それぞれh1とpタグが入っています。
image.png

上のdivタグのところだけ変えたいとします。つまりh1タグに囲まれた、「猫の一日」とpタグで囲まれた「ひたすら寝てます」の部分だけ文字の色を変えたいとします。

先ほど紹介した子孫セレクタを使用すると...

子孫セレクタの例
divh1,p{color:red;}

image.png

divタグが2つあるので、2つとも変わってしまいました。
そこで使えるのが、HTMLのclass属性とid属性を利用します。

class属性を使った場合

上のdivタグのところだけ変えたいので、そこにclass属性をつけ、下のdivタグと区別します。
classの名前を今回は"change_color"にしました。

HTML
<divclass="change_color"><h1>猫の一日</h1><p>ひたすら寝てます</p></div><div><h1>猫の遊び</h1><p>猫じゃらしで遊びます。</p></div>

CSSファイルは以下のように書きます。

CSS
.change_color{color:red;}

image.png
無事上のdivタグの中身だけ色を変えられましたね。

id属性を使った場合

class属性を付けていた部分をid属性に変えてみましょう。

HTML
<divid="change_color"><h1>猫の一日</h1><p>ひたすら寝てます</p></div><div><h1>猫の遊び</h1><p>猫じゃらしで遊びます。</p></div>

CSSファイルは以下のように書きます。

CSS
#change_color{color:red;}

コメント 2020-04-05 134343.png
先ほどと同じ結果になりました。

class属性とid属性の違いと、使い分け方法

上記では、「class」を使うか「id」を使うかの差だけで、ブラウザ上での表示効果は全く同じです。
では、「class」と「id」の違いは何でしょうか?使用上の違いを見てみましょう。

★class:
「種別名を割り当てる」
:point_right_tone2:同じclass名を、1ページ中に何度でも使える。

★id:
「固有の名前を割り当てる」
:point_right_tone2:同じid名は、1ページ中に1度しか使えない。

また、優先順位にも差があり、「idはclassよりも優先される」という規則があります。
そのため、極力idを使わずにclassだけで記述するほうが楽でしょう。

最後に

今回はCSSの適応方法と基礎文法でした。
次回はCSSを使って本格的に色を付けたり、フォントを変えたり…華やかなサイトづくりの続きをしていきましょう。


Viewing all articles
Browse latest Browse all 8669

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>