以下は私が見つけた比較的完璧な方法で、海外のデザイン専門家が純粋な CSS を使用して実現できます。テキストの内容が非常に小さい場合、下部がウィンドウの下部に表示されます。ウィンドウの高さを変更しても、重なり合う問題は発生しません。
<div id="wrap"> <div id="main" class="clearfix"> <div id="content"> </div> <div id="side"> </div> </div></div><div id="footer"></div>
手順: このレイアウトを使用するための前提条件は、フッターが一般的な div コンテナーの外側にある必要があることです。フッターはレイヤーを使用し、他のすべてのコンテンツは一般的なレイヤーを使用します。他の兄弟レイヤーを本当に追加する必要がある場合、この兄弟レイヤーは絶対位置決めにposition:absoluteを使用する必要があります。
CSS コード:
以下はメイン CSS コードです。これにより、下部がウィンドウの下部に配置されるようになります:
html, body, #wrap {height: 100%;}body > #wrap {height: auto; min-height: 100%;}#main {padding-bottom: 150px;} /* 必须使用和footer相同的高度 */#footer {position: relative; margin-top: -150px; /* footer高度的负值 */ height: 150px; clear:both;}
説明: 注意する必要があるのはパディングです。 #main の値、フッターの高さ、および負のマージンの値は一貫している必要があります。
とてもシンプルですが、まだ終わっていません。メインでフローティング レイアウトを使用している場合は、ブラウザの互換性の問題をいくつか解決する必要があります。ここでは、Google Chrome に焦点を当てます。
#main 部分で有名な Clearfix Hack を実行します:
.clearfix:after {content: "."; display: block; height: 0; clear: both; visibility: hidden;}.clearfix {display: inline-block;}/* Hides from IE-mac \*/* html .clearfix { height: 1%;}.clearfix {display: block;}/* End hide from IE-mac */
注: このソリューションは 2 列のフローティング レイアウトでテストされており、Google Chrome を含むすべての主要なブラウザーと互換性があります。
転載元: http://paranimage.com/css-sticky-footer/