0%

Programmingプログラミングナレッジ

Posted:2016.06.29

コンテンツが少ない時もフッターを最下段に配置する方法

WEBサイトでコンテンツエリアなどの内容が薄い場合に、コンテンツエリアの高さに合わせてフッター部分が上がってしまい、ウィンドウサイズが大きいと下部のエリアにスペースができてしまうことがあります。今回はそんな時でもウィンドウの最下段にフッターを配置する方法を備忘録として残しておきたいと思います。

 

CSSのpositionプロパティで最下段に設置

方法としてはいくつかありますが、今回はCSSのpositionプロパティを使ったやり方で進めていきます。まずはサンプルのHTMLから

 

【HTML】

<body>
    <div id="wrap">
        <header>ヘッダーエリア</header>
        <div id="content">コンテンツエリア</div>
        <footer>フッターエリア</footer>
    </div>
</body>

HTMLではコンテンツエリアとフッターエリアを囲う親要素を設置した構成にします。
次にCSSはこちらです。

 

【CSS】

html,
body {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
}
#wrap {
    margin: 0;
    padding: 0;
    width: 100%;
    min-height: 100%;
    position: relative;
}
#content {
    margin-bottom: 300px; //フッターエリアの高さ分の下マージンを設定しスペースをつくる
}
footer {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 300px; // フッターエリアの高さを指定する
    position: absolute;
    bottom: 0;
}

 

ポイントとしては、コンテンツエリアとフッターエリアを囲う親要素についてルート要素から高さ100%を継承し、positionにrelativeを設定します。

 

そして内包される要素のコンテンツエリアにはフッターの高さ分の下マージンを設定し、フッターが収まるスペースを設けます。フッターには高さを指定し、positionのabsoluteで親要素である#wrapを基準に絶対指定で最下段になるように配置させます。

 

これでコンテンツが少ない時でもウィンドウ最下段にフッターが配置されるようになります。

 

しかし、この方法であるとフッターの高さの値を必ず指定する必要があります。場合によってはフッターの高さを指定できないケースもあると思います。その時にはjQueryでフッターの高さを取得して、css()で同じ効果になるよう要素を操作します。

 

【jQuery】

$(window).on('load resize',function(){
    var footerH = $("footer").outerHeight();
    $("#content").css('margin-bottom', footerH + 'px');
    $("footer").css({
        'position':'absolute',
        'bottom':'0'
    });
});

 

このようにfooter要素のパディング、マージンを含めた高さを、outerHeight()で取得し変数に代入します。jQueryでのCSS操作で変数に代入したfooterの高さをコンテンツエリアの下マージンに設定します。ちなみに上記の例では関数を呼び出すイベントをページが読み込まれたときと、ウィンドウサイズを変更したときに設定しています。

 

こうすることでフッター要素の高さがわからないもしくは指定できない場合でも同じレイアウトを実装できます。あまり目につかないような細かい所ですがコンテンツが少ない可能性がある場合は見た目にも是非やっておいた方が良さそうですね。

 

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】