CSS は Cascading Style Sheets の略です。CSSは、HTMLで記述された Webページの見栄え・スタイルを効率的に定義するための技術です。HTMLで文書の意味を定義し、CSSで見栄えを定義することにより、意味と見栄えを分離することが可能となります。
最も基本的なCSSの使用例を下記に示します。この例では、<h1>~</h1> で囲まれたタイトル部が赤字で表示されます。「h1 { color: red; }」は、「h1 の部分の色(color)を赤(red)にする」という意味を持ちます。この例の「色」のような見栄えなどの情報を「スタイル」と呼びます。
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>CSSのテスト</title> <style> h1 { color: red; } </style> </head> <body> <h1>CSSとは</h1> <p>CSSはCascading Style Sheetsの略で・・・</p> </body> </html>
CSSの指定方法には下記のようなものがあります。
h1 や div や span や p など、大半のタグに style属性を用いて指定することができます。下記の例では、<h1>~</h1> で囲まれた「CSSとは」の文字が赤字で表示されます。
<h1 style="color:red;">CSSとは</h1>
セミコロン( ; )で区切って、複数のスタイルを指定することも可能です。最後のスタイルのセミコロン( ; )は省略可能です。
<h1 style="color:red; font-size: 24pt;">CSSとは</h1>
<style>~</style> で、文書全体のスタイルを指定することができます。下記の例では、文書中のすべての <h1>~</h1> が赤字で表示されます。
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>CSSのテスト</title> <style> h1 { color: red; } </style> </head> <body> <h1>CSSとは</h1> <p>CSSはCascading Style Sheetsの略で・・・</p> </body> </html>
<link> タグにより、外部CSSファイルを読み込むことができます。外部CSSファイルを用いることで、複数の HTML文書で共通のCSSを共有することができます。
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <link rel="stylesheet" href="style.css"> <title>CSSのテスト</title> </head> <body> <h1>CSSとは</h1> <p>CSSはCascading Style Sheetsの略で・・・</p> </body> </html>
外部CSSファイル(style.css)には、次のように記述しておきます。ファイル名は何でもよいですが、拡張子は通常 .css とします。
h1 { color: red; }
下記の様に @import を用いて外部CSSファイルを読み込むことも可能です。
<style> @import url(style.css); </style>
CSS2 では下記のような記法もサポートされました。
<style> @import "style.css"; </style>
CSS の基本動作は「○○要素の、○○というスタイルを、○○にする。」となります。例えば上記の例では、「h1要素の、色(color)スタイルを、赤(red)にする」となります。各用語の使い方を下記に示します。
下の図のそれぞれの枠が要素(element)となります。html要素の中に head要素と body要素が、body要素の中に h1要素と p要素があるように、要素は親子関係を持ちます。
<html>
|
親要素に指定されたスタイルの多くは、子要素に継承されます。例えば、h1 { color: red; } と定義されている時、親要素である h1要素の color属性は、子要素である em要素に継承され、「いいい」の部分も赤くなります。
<h1>あああ<em>いいい</em>ううう</h1>
CSS2 では、大半のスタイルで、親のスタイルを継承することを意味する inherit という値がサポートされました。通常では継承されないスタイルを継承させたり、継承することを明示的に示したい場合、に使用されます。IE8、Firefox 2.0、Opera 9 などでサポートされています。例えば下記の例では、リンクテキストを親要素と同じ色で表示します。
a { color: inherit; }
セレクタには、スタイルを適用する対象となる要素を指定します。要素の指定は様々な方法があります。
h1 { color: red; } /* h1要素に対して指定 */ h1, h2 { color: red; } /* h1 と h2要素に対して指定 */ ul li { color: red; } /* <ul>~</ul> の中にある li要素に対して指定 */ .sample { color: red; } /* class="sample" を持つ要素に対して指定 */ #sample { color: red; } /* id="sample" を持つ要素に対して指定 */ h1.sample { color: red; } /* class="sample" を持つ div要素に対して指定 */ a:link { color: red; } /* <a href="..."> のリンク(未訪問)に対して指定 */
詳細は「セレクタ」を参照してください。
まだ未サポートのブラウザもありますが、セレクタを階層的にネスティングして記述することもできます。詳細は「CSSネスティング」を参照してください。
/* と */ の間はコメントとして無視されます。
h1 { color:red; } /* Red Color */
コメントを入れ子にすることはできません。下記は、誤ったコメントの使用例です。
/* h1 { color:red; } /* Red Color */ */
ひとつの要素に相反するスタイルが指定された場合、下記の計算で求められたポイント(詳細度)の高いものが優先されます。
説明 | 例 | ポイント |
---|---|---|
!important | !important | 1/0/0/0/0点 |
style 属性 | style="..." | 1/0/0/0点 |
ID セレクタ | #xyz | 1/0/0点 |
クラスセレクタ | .xyz | 1/0点 |
属性セレクタ | [href^="http:"] | 1/0点 |
擬似クラス | :first-child | 1/0点 |
要素名 | ul | 1点 |
擬似要素 | ::before | 1点 |
セレクタの中に複数個出現した場合は、複数カウントします。例えば、下記の様に計算されます。
* { ... } /* 0点 */ ul { ... } /* 1点 (要素×1個)*/ ul li { ... } /* 2点 (要素×2個) */ h3::before { ... } /* 2点 (要素+擬似要素) */ .xyz { ... } /* 1/0点 (クラス) */ .xyz:first-child { ... } /* 2/0点 (クラス+疑似クラス) a[href^="http://"] { ... } /* 1/1点 (要素名+擬似クラス) */ #xyz { ... } /* 1/0/0点 (IDセレクタ) */ style="..." /* 1/0/0/0点 (stype属性) */ #xyz { ... !important } /* 1/0/1/0/0点 (!impotant+IDセレクタ) */
1点を積み重ねると11点になりますが、11点は 0/11点とカウントされ、1/0点を超えることはありません。同様に 1/0点を積み重ねて 11/0点としても、1/0/0点を超えることはありません。
ul ul ul ul ul ul ul ul ul ul li { ... } /* いくら点数を積み重ねて 11点としても */ .abc { ... } /* 上位のクラス 1/0点 を追い抜くことはない */
同じ優先度のスタイルが存在する場合は、CSS 定義で後から定義されたものが優先されます。例えば下記の例では、class="c2 c1" の並びではなく、.c1 と .c2 で、後から定義されたものが優先されます。
<style> .c1 { color: red; } .c2 { color: blue; } </style> <h1 class="c2 c1">青文字になります</h1> <h1 class="c1 c2">青文字になります</h1>
CSSカスケードレイヤー でレイヤーの優先度が指定されている場合は、上記の優先度よりもレイヤーの優先度が優先されます。
HTML の height=100 や width=100 は単位を書きませんが、CSS では数値が 0 の時を除いて単位は必須です。長さの単位に関する詳細は <length> を参照してください。
CSSを使用することのメリットには次のようなものがあります。
すべての H1要素に <font>~</font> を指定してまわるよりも、CSSで一度に指定した方が楽になります。外部ファイルで指定しておけば、より一層楽になります。
また、見栄えを外部ファイルに定義しておけば、それをちょっと変更するだけで見栄えを一度に変更することができます。春には春のスタイルを、秋には秋のスタイルを適用してやることもできます。この時、class=red のようなクラス名だと、.red { color:blue; } などと変更した時に妙な気分になるので、class=pastoral のような、見栄えに影響しない名前をつけておくとよいそうです。
Webページを自動収集して情報データベースを作成したり、目の見えない人が音声ブラウザでWebページを読む場合など、見栄えがあまり重要視されないケースもあります。見栄えを別のページで記述することにより、不要な見栄え情報を読み込んでくる煩わしさを解消することができます。