CSS实现定位DIV固定在网页底部
2012-12-24 13:43
405 查看
先说我们为什么会使用到这个CSS底部布局解决方案:
当做一个页面时,如果页面内容很少,不足于填充一屏的窗口区域,按普通的布局,就会出现下面图片中的样子(也就是底部内容并没有位于窗口的底部,而留下了大量空白。
对于追未完美的设计师来说,这是不美观的。网上有一些解决方案,但会出现当改变窗口高度时,底部和正文重叠的BUG。尽管没有多少人会有事没事儿的去改变窗口高度,但设计嘛,追求的就是尽善尽美。
下面是我找到的一个比较完美的方法,来自国外的设计达人,纯CSS,可以实现: 当正文内容很少时,底部位于窗口最下面。当改变窗口高度时,不会出现重叠问题。
HTML代码:
<div id="wrap">
<div id="main" class="clearfix">
<div id="content"> </div>
<div id="side"> </div>
</div>
</div>
<div id="footer"> </div>
说明: 使用这个布局的前提,就是footer要在总的div容器之外,footer使用一个层,其它所有内容使用一个总的层。如果确实需要到添加其它同级层,那这个同级层就必须使用position:absolute进行绝对定位。
CSS的简单在于它易学,CSS的困难在于寻找更好的解决方案。在CSS的世界里,似乎没有完美这种说法。所以,现在介绍的CSS绝对底部,只是目前个人见过的方案中比较完美的吧。
CSS代码:
下面是主要的CSS代码,让你的底部可以位于窗口的最下面:
html, body, #wrap {height: 100%;}
body > #wrap {height: auto; min-height: 100%;}
#main {padding-bottom: 150px;} /* 必须使用和footer相同的高度 */
#footer {position: relative; height: 150px; clear:both; margin-top: -150px; /* footer高度的负值 */ }
说明:需要注意的就是#main的padding值、footer的高度和负margin值,需要保持一致。
就是这么简单,不过还没完。如果你的主体是使用悬浮布局,还得解决一些浏览器的兼容问题,这里使用的重点是为了Goolge 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 */注: 该方案测试于两栏悬浮布局,兼容各大主流浏览器,包括Google Chrome。
当做一个页面时,如果页面内容很少,不足于填充一屏的窗口区域,按普通的布局,就会出现下面图片中的样子(也就是底部内容并没有位于窗口的底部,而留下了大量空白。
对于追未完美的设计师来说,这是不美观的。网上有一些解决方案,但会出现当改变窗口高度时,底部和正文重叠的BUG。尽管没有多少人会有事没事儿的去改变窗口高度,但设计嘛,追求的就是尽善尽美。
下面是我找到的一个比较完美的方法,来自国外的设计达人,纯CSS,可以实现: 当正文内容很少时,底部位于窗口最下面。当改变窗口高度时,不会出现重叠问题。
HTML代码:
<div id="wrap">
<div id="main" class="clearfix">
<div id="content"> </div>
<div id="side"> </div>
</div>
</div>
<div id="footer"> </div>
说明: 使用这个布局的前提,就是footer要在总的div容器之外,footer使用一个层,其它所有内容使用一个总的层。如果确实需要到添加其它同级层,那这个同级层就必须使用position:absolute进行绝对定位。
CSS的简单在于它易学,CSS的困难在于寻找更好的解决方案。在CSS的世界里,似乎没有完美这种说法。所以,现在介绍的CSS绝对底部,只是目前个人见过的方案中比较完美的吧。
CSS代码:
下面是主要的CSS代码,让你的底部可以位于窗口的最下面:
html, body, #wrap {height: 100%;}
body > #wrap {height: auto; min-height: 100%;}
#main {padding-bottom: 150px;} /* 必须使用和footer相同的高度 */
#footer {position: relative; height: 150px; clear:both; margin-top: -150px; /* footer高度的负值 */ }
说明:需要注意的就是#main的padding值、footer的高度和负margin值,需要保持一致。
就是这么简单,不过还没完。如果你的主体是使用悬浮布局,还得解决一些浏览器的兼容问题,这里使用的重点是为了Goolge 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 */注: 该方案测试于两栏悬浮布局,兼容各大主流浏览器,包括Google Chrome。
相关文章推荐
- 用CSS实现定位DIV绝对位于网页底部
- 纯css实现固定在页面底部的div层
- 响应式网页中,如何只用CSS实现div的高和宽保持固定比例
- 纯css实现固定在网页底部菜单导航
- footer固定在网页底部且居中,超过一屏自动撑开(最简单的CSS实现)
- CSS Div固定在网页顶部、底部、左侧、右侧
- css absolute定位,让层固定在网页的底部
- CSS固定在网页底部的层div
- DIV始终固定在网页右下角位置的CSS实现方法,返回顶部功能
- div footer标签css实现位于页面底部固定
- (div+css)上下固定中间自适应高度网页布局的实现
- 前端网页css实现固定定位
- (div+css)上下固定中间自适应高度网页布局的实现(FF,IE)
- Css如何定位网站的footer在固定位置(用DIV+CSS让footer始终在底部)
- css方法div固定在网页底部
- (div+css)上下固定中间自适应高度网页布局的实现(FF,IE)
- css方法实现div固定浏览器底端
- CSS案例,DIV固定在页面底部,不随滚动条的滚动。
- DIV+CSS+JS实现的可以随意拖动的网页布局
- 基于CSS的DIV网页设计 - 使用固定层方法设计网页