6
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

1人フロントエンドAdvent Calendar 2022

Day 14

header、footer、mainを組み合わせていい感じに表示する

Last updated at Posted at 2022-12-13

はじめに

世の中のほとんどのWebサイトにはヘッダーが使われていますし、フッターも多くのサイトで使われています。この記事ではそんな必要不可欠なヘッダーとフッターとメインをいい感じに配置する方法を紹介します。

理想

今回追い求めるのはヘッダーが画面のトップにあり、フッターが画面の一番下もしくはコンテンツの一番下にあるような配置です。

  • 全コンテンツの高さが画面の高さより低いときは、メインの下部に隙間を作りフッターを画面の最下部に配置する
    スクリーンショット 2022-12-13 22.01.11.png
  • 全コンテンツの高さが画面の高さよりも高いときは、フッターをメインの下に配置する
    スクリーンショット 2022-12-13 22.01.59.png
    スクリーンショット 2022-12-13 22.09.57.png

下記ような配置にはならないようにCSSで装飾します。このような配置は誤っていると主張しているわけではなく、今回実装する配置ではないということを表しています。

  • 全コンテンツの高さが画面の高さより低いときにフッターの下に隙間ができる
    スクリーンショット 2022-12-13 21.57.47.png
  • 全コンテンツの高さが画面の高さよりも高いときにフッターが画面下部に張り付く
    スクリーンショット 2022-12-13 22.27.54.png

gridを使って実装する

gridを使って実装する場合htmlは下のように構成します。

<div>
  <header></header>
  <main></main>
  <footer></footer>
</div>

divにgridを与えてヘッダー、メイン、フッターをいい感じに配置していきます。

div {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100lvh;
}

display: grid;は対象のグリッドレイアウト化を行っています。
grid-template-rows: auto 1fr auto;は領域の縦方向の分割方法を決めています。frは他の方法で指定した部分以外の配分を決める単位です。frの配分はflexのgrowと同じ配分方法です。ここではautoによって自動で割り当てられた箇所以外の領域を占有するようになっています。最初のautoがヘッダー、1frがメイン、最後のautoがフッターに対応します。つまり、ヘッダーとフッターが領域の上と下に配置されて残りの部分をメインが占有するようになります。grid-template-rowに対して横方法の分割方法を決めるgrid-template-columnsもあり、grid-template-columns: 100%とすることで全コンテンツの横幅を画面サイズより大きくならないようにできます。
min-height: 100lvh;は縦幅の最小値を決めています。100lvhにすることで画面の縦幅が全コンテンツの最小サイズになリマス。これによって全コンテンツの高さが画面の高さより小さい時でもそれらが画面いっぱいを占めるようになります。さらにgrid-template-rowsの設定によりヘッダーが画面の上、フッターが画面の下、メインが残りの部分を占めるようになります。

See the Pen Untitled by KokiSakano (@kokisakano) on CodePen.

この方法はシンプルなのでおすすめです。

flexを使って実装する

flexを使って実装する場合もhtmlは下のように構成します。

<div>
  <header></header>
  <main></main>
  <footer></footer>
</div>

divにflexを与えてヘッダー、メイン、フッターをいい感じに配置していきます。

div {
  display: flex;
  flex-direction: column;
  min-height: 100lvh;
}
main {
  flex-grow: 1;
}

行っていることはgridと同じです。
display: flex;は対象のフレックスレイアウト化を行っています。
flex-direction: column;は要素の並び方を上から下に並ぶようにしています。
min-height: 100lvh;は全コンテンツの高さの最小サイズを決めて、全コンテンツの高さが画面より小さかったとしても画面のサイズだけの領域を確保するようにします。
そして最後にmainにflex-grow: 1を与えています。これは、全コンテンツの高さが画面より小さいときにメインが残りの部分を占めるようにする設定です。

See the Pen grid-content by KokiSakano (@kokisakano) on CodePen.

この方法はメインにもcssを記述する必要があるのでコンテンツごとにファイルを分割したときなどに見通しが悪くなります。gridを使えない理由がない限りはこちらは使わない方が良いと考えています。

さいごに

ヘッダー、フッター、メインを並び替える方法をgrid、flexを使って紹介しました。簡単に設定できるので自分のWebサイトでもこのように設定したいと感じた方はぜひ採用してみてはいかがでしょうか。

6
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?