CSSでフッターをウィンドウ最下部に固定する方法【初心者向け】

初心者向けにCSSでフッターをウィンドウ最下部に固定する方法について解説しています。ページのコンテンツの量が多ければ問題ないのですが少ない場合はフッターがページの真ん中に表示されてしまうことがあります。コンテンツ量が少なくてもフッターをページ最下部に固定する方法について解説しています。

TechAcademyマガジンは受講者数No.1のオンラインプログラミングスクールTechAcademy [テックアカデミー]が運営。初心者向けに解説した記事を公開中。現役エンジニアの方はこちらをご覧ください。

今回は、CSSでフッターをウィンドウ最下部に固定する方法について解説します。

なぜCSSでフッターをウィンドウ最下部に固定する必要があるのでしょうか?

それは、ページのコンテンツ量が少ない場合、フッターを最下部に固定しないとデザインに違和感を感じる状態になるからです。

CSSでフッターをウィンドウ最下部に固定することができれば、コンテンツ量が少ない場合でもきれいにフッターデザインを実現できるようになります。

目次

 

田島悠介

今回は、CSSに関する内容だね!

大石ゆかり

どういう内容でしょうか?

田島悠介

CSSでフッターをウィンドウ最下部に固定する方法について詳しく説明していくね!

大石ゆかり

お願いします!

 

フッターを最下部に表示する書き方

ウェブデザインでは、フッターが画面下部にくっついているものは比較的多いです。

コンテンツがたくさんあって、全てのページが自然と縦長になるサイトなら全く問題ないのですが、コンテンツが少ないページがある場合、フッターを下に固定させ、なおかつ長いページのときは成り行きの位置に配置することが必要な場合があります。

そんな時に使える、jQueryを使わずにCSSだけで下部に固定させる方法を紹介します。

例えば、CSSに対して例えば次のような指定を行います。

footer{
    position: absolute;/*←絶対位置*/
    bottom: 0; /*下に固定*/
}

このcssはhtmlのfooter要素に対して適用するものです。

position: absolute;ではフッターの位置を絶対位置として指定しています。

絶対位置は、位置が絶対的に固定されるという意味です。

具体的にどの位置から絶対的に固定されるかと言うと、図の基準となるウィンドウの左上赤丸を起点としたときの絶対的な位置です。

今回であれば、bottom: 0;の位置で固定します

bottom: 0;で指定する固定位置を指定しています。これにより基準ウィンドウの下部、図で言うところの赤線に固定されるという処理が実装できます。

 

[PR] HTML/CSSで挫折しない学習方法を動画で公開中

実際に書いてみよう

まずは全体の枠の高さの最小値を決めます。

高さの最小値なので、min-heightを使います。

そしてブラウザによって高さは異なるので、vhという、画面の大きさを基準にした単位を使用します。

100vhが、ブラウザの画面の高さになりますので、まず.wrappermin-height: 100vh;と指定します。

.wrapper{
    min-height: 100vh;
}

footer{
    /*footerの装飾*/
    width: 100%;
    background-color: #89c7de;
    color: #fff;
    text-align: center;
    padding: 30px 0;
}

次に、positionの設定を書いていきましょう。

.wrapperを相対位置として、その中でfooterの位置を最下部に決めるようにします。

.wrapper{
    min-height: 100vh;
    position: relative;/*←相対位置*/
}

footer{
    width: 100%;
    background-color: #89c7de;
    color: #fff;
    text-align: center;
    padding: 30px 0;

    position: absolute;/*←絶対位置*/
    bottom: 0; /*下に固定*/
}

これで、最下部に固定されました。

しかし、このままでは下図のようにコンテンツと被ってしまうタイミングがあります。

これを解決するには、padding-bottomとbox-sizingを使います。

.wrapperにまず、footerの高さ分のpadding-bottomを与えます。

このままだと、コンテンツが少ない時も下にはみ出てしまうので、続けてbox-sizing: border-box;を与えて、paddingを含めて、min-height:100vhになるようにします。

.wrapper{
    min-height: 100vh;
    position: relative;/*←相対位置*/
    padding-bottom: 120px;/*←footerの高さ*/
    box-sizing: border-box;/*←全て含めてmin-height:100vhに*/
}

footer{
    width: 100%;
    background-color: #89c7de;
    color: #fff;
    text-align: center;
    padding: 30px 0;

 position: absolute;/*←絶対位置*/
    bottom: 0; /*下に固定*/
}

これで、コンテンツが少ない時も、下に固定されるfooterを作ることができました。

この記事を監修してくれた方

中本賢吾(なかもとけんご)
アジマッチ有限会社 代表取締役社長開発実績:PHPフレームワークによるフランチャイズ企業向け会員制SNS。Shopifyによる海外進出用大規模ネットショップ構築。Vue.jsによる金融機関向け内部アプリ。AWSやLinuxハウジングサーバーでの環境構築。人工知能を利用した画像判別システム。小売チェーン店舗用スマホアプリ。Wordpressによる不動産チェーン店向け賃貸・売買仲介システム。基幹システム移管用データコンバートシステム。小学生がUnityでオリジナルAndroidアプリをGooglePlayでリリース、NHK Whyプログラミング入賞、全国Programing Festival入賞、中学生がノーコードでSNS型PWAアプリリリースなど、ボランティアプログラミング教育活動行っている。

 

大石ゆかり

内容分かりやすくて良かったです!

田島悠介

ゆかりちゃんも分からないことがあったら質問してね!

大石ゆかり

分かりました。ありがとうございます!

 

CSSを学習中の方へ

これで解説は終了です、お疲れさまでした。

  • つまずかず「効率的に」学びたい
  • 副業や転職後の「現場で使える」知識やスキルを身につけたい

CSSを学習していて、このように思ったことはありませんか?

テックアカデミーのWebデザインコースでは、第一線で活躍する「プロのWebデザイナー」が教えているので、効率的に実践的なスキルを完全オンラインでしっかり習得できます。

合格率10%の選考を通過した、選ばれたWebデザイナーの手厚いサポートを受けながら、オリジナルのWebサイト制作を完全オンラインでしっかり習得できます。

まずは一度、無料体験で学習の悩みや今後のキャリアについて話してみて、「現役Webデザイナーから教わること」を実感してみてください。

時間がない方、深く知ってから体験してみたい方は、今スグ見られる説明動画から先に視聴することをおすすめします!