CSSとは
CSS(シー・エス・エス)とは、「Cascading Style Sheets(カスケーディング・スタイル・シート)」の頭文字を取った言葉で、ウェブページの見た目や振る舞いを定義するための言語です。HTMLで記述したウェブページを画面に表示する際に、装飾や配置について柔軟に制御できる仕組みが備わっています。
CSSはスタイルシート言語(Style sheet language)の一種です。コンピューターが扱う様々な言語の中の方言だと思って下さい。
元々、スタイルシート(Style Sheet)は、HTMLに限らずSGMLやXMLといったマークアップ文書や、オフィスソフトなどの表示形式を制御するために考案されました。中でもCSSは、インターネットの爆発的な普及によって、最も一般的な形式として利用されるようになりました。そのため、本サイトでは「スタイルシート = CSS」として説明します。
CSSの役割と重要性
かつてCSSが未熟な時代のHTMLは、「文書の構造を整える機能」と「画面に映した時の見た目を装飾する機能」が混在していて、非常に扱いづらい言語でした。その問題を解決するために進化したのがCSSです。
CSSが成熟したことによって、HTMLはドキュメントの構造を定義することに専念できるようになりました。HTMLとCSSの役割分担は、バージョンが上がるごとに洗練されています。これにより、まず第一に制作者の学習コストが下がりました。そして制作者が意図したデザインをウェブページに反映させやすくなりました。さらに一番重要なこととして、ブラウザの実装方針が定まり、不具合が減少した事に加えて実現できる機能が多彩になりました。
CSSは、HTMLから表示方法を切り離して役割分担を明確にしました。その結果、ウェブ制作の合理化に貢献し、なくてはならない存在となったのです。
CSSとブラウザの関係
ウェブページは、ウェブサーバーに公開されたドキュメントファイルを、ウェブブラウザが読み込むことによって表示されるものです。その性質上、CSSはブラウザの読解能力に依存しています。
もしも、ブラウザごとに実装されているCSSの仕様が全く違うものだとしたら、制作者は正しい記述形式が分からずに混乱するばかりか、利用するブラウザごとにウェブページの表示が異なるため、インターネットを利用する全ての人が利便性を損なってしまいます。
そんなことが起こらないように、ブラウザを開発する企業(「ベンダー」と呼ばれます)は、HTMLやCSSの仕様に従ってブラウザの機能を更新しています。しかし、ブラウザの種類やバージョンによっては、制作者の意図した通りに表示されないこともあります。そのため、一般的に普及しているブラウザの市場規模とCSSの実装状況は密接に関わっているのです。
上記のような経緯から、自分の制作したウェブページをインターネット上に公開する時、世の中で利用者の多いブラウザでテスト表示を行い、自分の意図した表示が崩れないか、情報伝達に支障が起きない形になっているかを確認する必要があるのです。
CSSの仕様は誰が決めているのか
CSSは、W3C(World Wide Web Consortium)によって1996年に勧告され、現在に至るまでバージョンアップを重ねています。現在は、2011年以降に勧告されたCSS3がメジャーバージョンになっています。元々W3Cは、HTMLの考案者でもあるティム・バーナーズ=リーがWorld Wide Webの標準を策定するために創設した団体です。
基本的には、W3Cで協議された内容が正式に勧告されると、それを「ウェブ標準」として各ソフトウェアベンダーがブラウザに実装します。アップデートが完了すると、ユーザーへの配布が始まるため、制作者は自ら作成するドキュメントで新しい仕様のCSSが利用可能とみなされます。しかし、ここに大きな落とし穴がありました。
まず、仕様が勧告されてからブラウザに実装されるまでの時間がベンダーごとに異なること。そして、ブラウザごとに「実装のされ方」が異なる場合があり、制作者が仕様通りに記述しても予想通りに表示されないことがあるということです。そして、最新版のブラウザが配布されても、ユーザーがアップデートしなければバージョンは古いままであり、その利用者に対しては新しい仕様は使えないという問題も起こります。
さらに、W3Cの方針や進め方が、ベンダーや制作者のニーズに合わないという声が高まったことによって、WHATWGという新しい団体が作られました。この団体は、Apple、Mozilla、Operaによって創設されましたが、まさに主要なブラウザを作っている企業が自分たちで組合を立ち上げたことになります。
このような歴史的背景から、HTMLはW3CとWHATWGという二つの組織によって別々に標準化が進められました。そして現在、そのねじれた環境から脱却し、有効な仕様は名実ともに「HTML Living Standard」に統一されました。私たち個人のウェブ制作者は、まず安定稼働が確認された現実的な範囲で基礎を固め、それから最新の情報を必要に応じて追っていく必用があります。
現在、HTMLの標準仕様はWHATWGによって勧告されます。一方、CSSの仕様は引き続きW3Cが勧告を行います。
CSSを効率良く勉強する方法
CSSを効率良く勉強する方法の第一は、実際に手を動かして書いてみることです。基礎的な知識は上記で説明した通りです。後は書いて、書くしかありません。
一般的な書き方は、サンプルをコピー&ペーストして必用な箇所をアレンジしていく方法です。その中から頻繁に使うパターンを見つけて覚えておくと便利です。たまにしか使わないパターンや新しい表現方法は、必要になった時点で検索していけば良いでしょう。最初のうちは、ネット上に書かれた情報が正しいのか間違っているのかを判断することが難しいため、信頼できる書籍を一冊買っておくことをお薦めします。
そして、これが出来れば最も素晴らしい手段なのですが、既にCSSの知識を持っている「先生」を見つけて教えてもらうことです。ウェブデザイナーやフロントエンジニアとして仕事の経験がある人が身近にいるのであれば、あなたの書いたソースコードをレビューしてもらいアドバイスをもらいましょう。そのような人が身近にいない場合は、インターネット上のコミュニティに参加して、コメントをもらうというやり方でも問題ありません。とにかく、書いたコードを人に見てもらえる環境が大事です。
CSSリファレンス一覧
-
CSSって何?初心者が最初に学ぶべき基礎知識
初めてCSSに触れる方はこちらから読み進めて下さい。CSSの役割やブラウザとの関係など、初心者にも分かりやすいように基礎知識を解説します。
入門編 -
CSSの書き方を詳しく解説!基本的な型とルールを覚えよう
CSSの書き方には一定の法則があるので、慣れてしまえば迷うことはないでしょう。まずは基本的な文法をマスターしましょう。
初級編 -
CSSの特徴をしっかりと把握しよう
CSSにはいくつかの特徴があります。これらを早いうちに理解しておくと、ウェブ制作の作業効率が格段に上がります。
初級編 -
CSSファイルの作り方
CSSファイルは誰でも簡単に作成できます。特別な技術やソフトウェアは必要ありません。
初級編 -
CSSセレクタの一覧表
スタイルの適用対象となる要素を選択するセレクタの一覧表です。詳しい書き方やサンプルコードを掲載しています。
学習編 -
CSSで使える単位の一覧表
プロパティの指定に用いる単位の解説です。CSSで使用できる単位の一覧表を掲載しています。
学習編 -
ボックス・モデルの完全解説
CSSの基礎が固まってきたらボックス・モデルについて学びましょう。これを理解するとCSSの操作が格段にやりやすくなります。
中級編 -
ブロックレベルとインラインレベルを理解する
CSSのブロックレベルとインラインレベルの特性について解説します。これらの扱いはHTMLからボックス・モデルに引き継がれました。
中級編 -
CSSの余白を表すmarginとpaddingを正しく理解する
要素の余白を表すmarginとpaddingについて正しい知識を身に着けましょう。
中級編 -
idとclassを上手く使い分ける
idセレクタとclassセレクタの使い分け方を詳しく解説します。
中級編 -
全称セレクタ(ユニバーサル・セレクタ)の解説
全ての要素のプロパティを一括で操作する全称セレクタについて解説します。
中級編 -
リストのデザインをマスターする
リストのデザインに関するCSSのテクニックを多数紹介します。入れ子、多段式、横並びを全て解決します。
応用編 -
フレックス・ボックスを理解する
横並びのレイアウトやレスポンシブデザインに対応するフレックス・ボックス(Flexible Box)について解説します。
応用編 -
グリッド・レイアウトを理解する
複数の行と列を作成して多次元のレイアウトを行うグリッド・レイアウトについて解説します。
応用編