Memorandum

Something about Information Technology

CSS

全般

ツール

Coding

JS Bin
HTML文法チェック CodePen

Diff

CODE DIFF
Diff Checker
Mergely
difff

CSS

CSSリファレンス
セレクタ一覧
CSSのセレクタとは?覚えておきたい25種類と書き方
PX to Percent Converter
WEB GENERATOR
カラーコード変換ツール (16進数、RGB、RGBA)
カラーコード変換 (RGB、HSV、HSL、CMK、CMYK)
Bootstrap Icons

参考情報

sectionとdiv

ベースHTML

<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width">
    <title>タイトル</title>
    <meta name="description" content="ページの説明">

    <!-- リセットCSS -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/ress@4.0.0/dist/ress.min.css">
    <!-- Google Fonts -->
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap" rel="stylesheet">
    <!-- Bootstrap Icons -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.9.1/font/bootstrap-icons.css">
    <!-- CSS-->
    <link rel="stylesheet" href="./css/style.css">

  </head>
  <body>
  </body>
</html>

CSSの書き方

  • HTMLの各タグの中にstyle属性を追加し、属性値としてCSSを記述する
  • head要素の中に<style>というタグ(要素)を追加し、<style> の内容としてCSSを記述する
  • CSSファイルを用意し、ファイルの中にCSSを記述する

HTMLの各タグ内にstyle属性として適用

style属性を使うことで、HTMLタグの中に直接CSSを書き込むことができます。

<h1 style="color: red;">ここが赤文字</h1>

この方法は、制作作業中に一時的にスタイルの確認をしたいときなどに有用です。この方法はhead要素内で読み込まれたスタイルよりも確実に後から読み込まれるので、 HTMLタグ内に記述したCSSは常に優先的に適用される と覚えてください。

head内にstyleとして適用

<head>要素内で使用可能な<style>タグの中にCSSを記述できます。下記のようにhead要素のstyle要素としてCSSを書くと、記述したHTMLファイル内のbody要素だけに適用されます。

<head>
    <style>
        h1.red {
            color: #ff0000;
        }
    </style>
</head>

(推奨)外部ファイルとして読み込む

こちらが 推奨される方法 です。CSSを適用したいHTMLのhead要素内にlink要素を書き込むことで、外部のCSSファイルを読み込むことができます。下記のソースコードでは、style.cssというファイルを読み込み、style.css内のCSSを適用します。

<head>
    <!-- 中略 -->
    <link rel="stylesheet" href="style.css">
</head>

CSSファイルはHTMLと同じく、テキストファイルです。テキストエディタを使用して作成・編集します。保存したファイルの拡張子を「.css」にすることで、WebブラウザにCSSファイルとして認識されます。

外部ファイルとして読み込む理由としては、外部ファイルにして共有化したほうがサイト全体としてのメンテナンス性が高く保てること、また各々のHTML文書が簡素化され、視認性がよくなることなどが挙げられます。

HTMLとCSSの考え方の基本として、文書であるHTMLと、デザイン指定であるCSSは別ファイルで管理すべきという考えがあります。

文書とデザインではその役割がまったく異なるので、それぞれの役割に沿ってファイルを分けようという考え方です。そのことからも、上記の3つの方法のうち、CSSを外部ファイルとして読み込んで適用するのが推奨される方法 です。

セレクタ

  • デザインを適用する範囲を指定するもの
  • HTML要素全体に対してデザインを指定するのがもっとも単純な方法
  • class属性、id属性を組み合わせるのが一般的

要素全体のセレクタ

セレクタ {
    プロパティ: 値;
}

下記の例では、p要素やh1要素を指定しています。

/* h1要素のの文字色(color)を赤(red)にする */
h1 {
  color: red;
}

/* p要素のマージン(margin)を40pxにする */
p {
  margin: 40px;
}

class属性で指定するセレクタ

特定の要素

importantというclass属性を持ったp要素にデザインを適用

p.highlight {
  color: red;
}
全ての要素

同じclass属性を持った全ての要素に対してデザインを適用する場合

.highlight {
  color: red;
}
複数のclass属性を持つ要素
.highlight {
  color: red;
}

.highlight.bold {
  font-weight: bold;
}
<p class="highlight bold">見出し</p>
<p class="highlight">リスト</p>
class属性の親子関係を持つ要素
<div class=highlight>
  <div>見出し</div>
  <div class=list>リスト</div>
  <div class=list2>リスト2</div>
</div>
.highlight {
  color: green;
}

.highlight .list {
  color: red;
}

.highlight .list2 {
  color: yellow;
}

id属性で指定するセレクタ

id属性で指定する場合は、# を使用します。id属性は、1つのHTMLファイル内で一意(ダブらない)が推奨されていますので、1つのWebページの中で、ただ1つの要素を識別したいときに指定します。

#important {
  color: blue;
}

子孫セレクタ

特定の階層構造になっている要素にデザインを適用する場合

以下は<article></article>内の<p>要素に対してデザインを適用する例

article p {
  color: orange;
}
<p>テキストです</p>
<article>
  <p>article > pの文章</p>
</article>

子孫セレクタ (直接の子孫だけに適用する場合)

特定の階層構造になっている要素にデザインを適用する場合

以下は<article></article>直下の<p>要素にデザインを適用する例

article > p {
  color: orange;
}
<p>テキストです</p>
<article>
  <p>article > pの文章</p>
  <div>
    <p>article > div > pの文章</p>  <!-- これには適用されない -->
  </div>
</article>

隣接セレクタ

h2の直後のp、など特定の要素に隣接した要素にデザインを適用する場合

<p>テキストです(この要素にはcolor: pink;は指定されません)</p>
<h2>h2タイトルです</h2>
<p>テキストです</p>
<p>テキストです(この要素にはcolor: pink;は指定されません)</p>
h2 + p {
  color: pink;
}

特定の属性値をもつ要素のみを指定するセレクタ

ある属性が「指定した値」になっている要素を指定する場合、要素名[属性名=○○] のような書き方をします。

<!DOCTYPE html>
<html lang="ja">
    <head>
        <meta charset="UTF-8">
        <title>HTML/CSS</title>
    </head>
    <body>
        <a href="https://www.yahoo.co.jp">Yahoo! JAPAN</a><br>
        <a href="https://www.google.co.jp">Google</a><br>
        <a href="https://www.bing.com">Bing</a><br>
        <a href="https://example.com">Example</a><br>
    </body>
</html>
a[href="https://example.com"] {
  color: green;
}

CSSファイル内でのセレクタの優先順位

  • 下に書かれたものほど優先
  • 詳細なセレクタほど優先

疑似クラス

疑似クラスを使うことで、特定の状態になっている要素にのみデザインを適用できます。

リンクの状態に関するもの

a:link {
    color: #0000ff;
}
a:hover {
    color: #ff0000;
}
a:visited {
    color: #999999;
}

a:linkは未訪問のリンクです。未訪問リンクの文字色を青に指定します。 a:hoverは要素にカーソルが乗っている状態です。a要素にカーソルを合わせると文字色が赤になるように指定しています。 a:visitedは訪問済みのリンクです。訪問済みリンクの文字色はグレーになるように指定しています。

条件に基づいた兄弟グループの要素を指定する疑似クラス

liの並び位置でデザインを指定

/* 一番最初の要素 */
.first-last li:first-child{
  color: red;
}

/* 一番最後の要素 */
.first-last li:last-child{
  color: orange;
}

/* 2番目の要素 */
.nth-child li:nth-child(2){
  color:blue;
}

/* 3倍の整数に該当する順番の要素 */
.nth-child li:nth-child(3n){
  color: gray;
}

/* 奇数の要素、oddの代わりに2n+1と入れても同じ */
.odd-even li:nth-child(odd){
  background: yellow;
}

/* 偶数の要素、evenの代わりに2nと入れても同じ */
.odd-even li:nth-child(even){
  background: skyblue;
}

否定擬似クラス

特定のセレクタだけ指定したくない場合は、:not()を使います。:not()の()の中には、除外したいセレクタを記述します。

<ul>
  <li>リスト1</li>
  <li>リスト2</li>
  <li>リスト3</li>
  <li>リスト4</li>
</ul>
li:not(:last-child) {
  border-bottom: 1px solid #000;
}

擬似要素

:before を使うと「要素の内容の 先頭」、:after を使うと「指定の要素の 末尾」にスタイルを適用します。

2つとも、おもに content という特殊なプロパティとともに使います。content は、:before や :after で追加したい内容を指定するためのプロパティです。

HTML

<p class="pseudo">ヴァン</p>

CSS

.pseudo:before {
    content: "ルートヴィヒ・";
}

.pseudo:after {
    content: "・ベートーヴェン";
}

OUTPUT

ルートヴィヒ・ヴァン・ベートーヴェン

基本プロパティ

テキストの色、大きさ、揃え方

  • color
  • font-family
  • font-size
  • font-weight など

Example

div {
  text-align: center; /* 横方向の整列 */
}

p {
  color: red; /* 文字色 */
  font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif; /* フォント */
  font-size: 24px; /* 文字サイズ */
  font-weight: 700; /* 文字の太さ */
  line-height: 2; /* 行間 */
  letter-spacing: 10px; /* 字間 */
}

img {
  vertical-align: bottom; /* 縦方向の整列 */
}

背景色、背景画像

  • background-color
  • background-image
  • background-repeat
  • background-size
  • background-position など

Example

.background-color {
  width: 200px;
  height: 200px;
  background-color: gray; /* 背景色 */
}

.background-triangle {
  width: 300px;
  height: 100px;
  background-image: url("https://techacademy.s3-ap-northeast-1.amazonaws.com/bootcamp/webdesign/3/html-css/triangle.png"); /* 背景画像 */
  background-repeat: no-repeat; /* 背景画像繰り返し無し */
}

.background-image {
  width: 300px;
  height: 200px;
  background-image: url("https://techacademy.s3-ap-northeast-1.amazonaws.com/bootcamp/webdesign/3/html-css/bg.jpg"); /* 背景画像 */
  background-size: cover; /* 画像の縦横比を保ちながら表示領域いっぱいに表示 */
  background-position: 50% 50%; /* 背景画像の位置 */
}

色の記法

英語:red, green, blue, …
RGB(16進数):#000000 から #ffffff まで RGBA関数:(例)rgba(0,0,0,0)

詳細度の計算方法(MDM)

線を表示

div要素に使用
border
border-top 、border-right 、border-bottom 、border-left

table要素に使用
border-collapse: {separate | collapse}

collapse 隣接するセルのボーダーを重ねて表示します。

separate 隣接するセルのボーダーを間隔をあけて表示します。

リストのスタイル

リストのスタイルを変更するプロパティ
list-style

ボックスに影を付ける

box-shadow

レイアウト関連

サイズ記法

絶対指定 px
相対指定 %、em、rem、vw

パーセント

親要素に対して相対的なパーセンテージを指定
htmlタグのスタイルでfont-sizeをパーセント指定した場合は、ブラウザのデフォルトフォントサイズに対するパーセント指定となる。
ブラウザのデフォルトフォントサイズは標準で16px。

html {
    font-size: 62.5%; // 16 x 62.5% = 10px
}
em

親要素の文字サイズに対しての大きさを指定します。後述するremとの違いは、直近の親要素をもとにした単位という点になります。基本的にはremを使用することが多く、直近の親要素をもとに値を指定したいときにemを使用します。

rem

remは、すべての要素の親(root)であるhtmlセレクタを基準として計算されます。以下のサンプルでは、rem単位を使用してh1要素のフォントサイズを24pxにしています。

vw(Viewport Width)

ブラウザの幅に応じて、要素の大きさを変えたい場合に利用します。

たとえば、ブラウザの幅が1920pxのとき、100vwは1920pxと同じ大きさになります。10vwは192pxとなります。ブラウザの幅が変わると、1vwあたりのpx数も変わります。

これを使うと、画面の幅に応じてフォントサイズや画像の大きさを変えたりできるので、後ほど学ぶレスポンシブデザインで利用されます。

備考

em, remで相対指定しておくと、root font-sizeを変更したらそれに合わせて全体のフォントサイズが調整されるので、おそらく実環境ではem/rem相対指定が多いのではないか。

サイズ指定

サイズ指定を相対指定する場合、ブラウザのフォントサイズ(デフォルト16px)が基準になる。
例えば max-width: 67.5rem; と指定されている場合、その領域の最大横幅は 1080px (16px x 67.5) となる。

width、height
max-width
calc()関数

余白

margin - 要素の外側の余白

margin … 上下左右まとめて指定
margin-top、margin-right、margin-bottom、margin-left … 上下左右それぞれ指定

margin: (上) (右) (下) (左);
margin: (上) (左右) (下);
margin: (上下) (左右);
margin: (上下左右);

padding - 要素の内側の余白

padding … 上下左右まとめて指定
padding-top、padding-right、padding-bottom、padding-left … 上下左右それぞれ指定

padding: (上) (右) (下) (左);
padding: (上) (左右) (下);
padding: (上下) (左右);
padding: (上下左右);

配置

positionは、要素がどのように置かれるかを決めるプロパティ。
positionプロパティの値には初期値の static に加えて relative、absolute、fixed の4つがある。

position: static
  • position プロパティのデフォルト値
  • 前のオブジェクトの下に配置
  • top、left など位置指定プロパティが使えず左上から要素を並べるレイアウト
  • 自身の下端が次のオブジェクトの基点になる
position: relative
  • 前のオブジェクトの下に配置
  • 相対的に位置指定(本来位置からtop/left/right/bottomへの距離を指定)
  • 自身の上端が次のオブジェクトの基点になる
position: absolute
  • 親divブロック(relative)の基点が自身の基点になる
  • 親divブロック(relative)がない場合はbody(ウィンドウ画面)が基点になる
  • 絶対的な位置指定(top/bottom/left/right で各方向の端からの距離を指定)
position: fixed
  • 常にbody(ウィンドウ画面)が基点になる
  • 絶対的な位置指定(top/bottom/left/right で各方向の端からの距離を指定)
  • 親divブロック(relative)の基点が自身の基点になる
  • スクロールしても移動しない

divブロックのpositionがrelativeの場合、その子要素(div)のabsolute,fixedの基点になる。
relative はこの値を指定した要素が子要素 absolute や fixed の基準位置となる。 そのため、position: relative;position: absolute; はセットで使われる。

absoluteかfixedにすると、次のオブジェクトの基点としてdivブロックが考慮されない。
divブロック自身も他のオブジェクトと関係なく絶対ポジションとして設定した場所に置かれる。

top,left,right,bottom

基準位置からの距離を設定。

top 下方向
left 右方向
right 左方向
bottom 上方向
transform

transformはオブジェクトに動きをつけるプロパティ。
posisiontop left と組み合わせてオブジェクトをページ真ん中に持ってくることもできる。

transform: translate(x軸の距離, y軸の距離);
これはオブジェクトをx軸方向、y軸方向にそれぞれ指定した距離だけ移動させる。
%指定の場合は自身のサイズが基準になる。

カバーページでオブジェクトをページ真ん中に持ってくる場合の記述。

<!--- HTML --->
<section class="cover">
  <div class="cover-title">
    <h1 class="cover-catch">キャッチコピー</h1>
    <a href="./index.html" class="cover-button">ボタン</a>
  </div>
  <img src="https://..../cover.jpg" alt="">
</section>

/*--- CSS ---*/
.cover {
  position: relative;
}

.cover-title {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  text-align: center;
}

transform:translate()の使い方

display

display: block

ブロックレベル要素。
要素の横幅がブラウザの幅一杯になり、次に続く要素は改行される。
幅・高さ・余白などの調節が可能。
見出しや段落など、文章を区切りたいときに使用。

デフォルト設定が display: block; の要素

  • h1, など見出し要素
  • div
  • section
  • article
  • p
  • ul, ol
  • table
display: inline

インライン要素
要素が横に並ぶ。幅や高さは調節できない。
文章の一部にスタイルを適用する場合に使用。

デフォルト設定が display: inline; の要素

  • span
  • a
  • img
display: inline-block

余白や幅、text-alignなどが設定できるブロックレベル要素を、インラインレベル要素のように横へ並べる。
リスト<li>を横並びにする時に使う。

<!--- HTML --->
<ul class="inline-block">
  <li><a href="#">TOP</a></li>
  <li><a href="#">ABOUT</a></li>
  <li><a href="#">MAP</a></li>
  <li><a href="#">BLOG</a></li>
  <li><a href="#">CONTACT</a></li>
</ul>

/*--- CSS ---*/
.inline-block li {
  display: inline-block;
  border-radius: 0.8rem;
  padding: 0.1rem 0.5rem;
  background-color: black;
}

.inline-block li a {
  color: white;
}
display: none

非表示にする

display: flex

Flexboxにする

box-sizing

content-box

ボックスの幅にpaddingとborderを含まない。
デフォルト値(box-sizing を指定しない場合はこれが適用される)。

border-box

ボックスの幅にpaddingとborderを含む。

ボックスモデル

ブロックレベル要素をボックス(四角形の領域)として、大きさを指定してレイアウトしていく。

CSSプロパティ ボックスモデルの領域
margin 外側の余白
border 境界線
padding 内側の余白
width 横の幅
height 縦の高さ

flexbox

「Flexible Box Layout Module」
いまのWebレイアウトの主流。
display: flex;

flexboxでできること
  • 横並び、縦並びの調整(デフォルトは横並び)
  • 並び順の調整(逆順、位置指定)
  • 横の位置指定(左寄せ、右寄せ、中央寄せ、両端揃え、均等配置)
  • 縦の位置指定(高さを自動で揃える、上揃え、下揃え、中央揃え)
  • 折り返して複数行に配置
flexコンテナとflexアイテム

親要素(コンテナ)で display: flex; を指定し、子要素(アイテム)を配置していく。
以下は基本的な形(デフォルトは横並び)

<!-- HTML  -->
  <div class="container">
    <div class="item">1</div>
    <div class="item">2</div>
    <div class="item">3</div>
    <div class="item">4</div>
  </div>

/*--- CSS ---*/
.container {
    display: flex;
}
.item {
  width: 20%;
  height: 80px;
  padding: 10px;
  margin: 10px;
  background: #FFE966;
}
プロパティ
flex-direction

横並び、縦並び、正順、逆順

row(デフォルト値) 横並び
row-reverse 逆向きの横並び
column 縦並び
column-reverse 逆向きの縦並び
justify-content

主軸方向(通常は横方向)のコンテンツの寄せ方

flex-start 左寄せ
flex-end 右寄せ
center 中央寄せ
space-between 両端揃えの均等配置
space-around 余白を均等
align-items

交差軸方向(通常は縦方向)のコンテンツの寄せ方
align-items を指定をしない場合はコンテンツの量によらず、flexアイテムの高さはflexコンテナ内で100%

baseline ベースライン揃えでコンテンツ量によって高さが変動
flex-start 上揃えでコンテンツ量によって高さが変動
flex-end 下揃えでコンテンツ量によって高さが変動
center 中央揃えでコンテンツ量によって高さが変動
stretch コンテンツの量や大きさによらず高さが揃う
flex-wrap

flexアイテムの折り返しの有無

nowrap(デフォルト値) 折り返し無し
wrap 折り返し有り
order

同じflexコンテナに属するflexアイテムの表示順序を指定
指定した値が小さい順に表示されます (初期値は0)

column-gap

flexアイテムの要素同士に横方向の余白

row-gap

flexアイテムの要素同士に縦方向の余白