CSS Sticky Footer:&nbs…
2013-09-15 10:27
309 查看
CSS的简单在于它易学,CSS的困难在于寻找更好的解决方案。在CSS的世界里,似乎没有完美这种说法。所以,现在介绍的CSS绝对底部,只是目前个人见过的方案中比较完美的吧。
先说我们为什么会使用到这个CSS底部布局解决方案:
当做一个页面时,如果页面内容很少,不足于填充一屏的窗口区域,按普通的布局,就会出现下面图片中的样子(也就是底部内容并没有位于窗口的底部,而留下了大量空白。
对于追未完美的设计师来说,这是不美观的。网上有一些解决方案,但会出现当改变窗口高度时,底部和正文重叠的BUG。尽管没有多少人会有事没事儿的去改变窗口高度,但设计嘛,追求的就是尽善尽美。
下面是我找到的一个比较完美的方法,来自国外的设计达人,纯CSS,可以实现:
当正文内容很少时,底部位于窗口最下面。当改变窗口高度时,不会出现重叠问题。
甚至,创造该CSS的人还专门成立一个网站介绍这个CSS底部布局方案。不知道他有没有去申请专利:)
代码写法
html代码:
说明:
使用这个布局的前提,就是footer要在总的div容器之外,footer使用一个层,其它所有内容使用一个总的层。如果确实需要到添加其它同级层,那这个同级层就必须使用position:absolute进行绝对定位。
CSS代码:
下面是主要的CSS代码,让你的底部可以位于窗口的最下面:
html,
body, #wrap {height: 100%;} body > #wrap {height: auto;
min-height: 100%;} #main {padding-bottom: 150px;} #footer
{position: relative; margin-top: -150px; height: 150px;
clear:both;}
说明:
需要注意的就是#main的padding值、footer的高度和负margin值,需要保持一致。
就是这么简单,不过还没完。如果你的主体是使用悬浮布局,还得解决一些浏览器的兼容问题,这里使用的重点是为了Goolge
Chrome。
对#main部份进行著名的Clearfix Hack:
.clearfix:after
{content: "."; display: block; height: 0; clear: both; visibility:
hidden;} .clearfix {display: inline-block;} * html .clearfix {
height: 1%;}.clearfix {display: block;}
注: 该方案测试于两栏悬浮布局,兼容各大主流浏览器,包括Google
Chrome。
先说我们为什么会使用到这个CSS底部布局解决方案:
当做一个页面时,如果页面内容很少,不足于填充一屏的窗口区域,按普通的布局,就会出现下面图片中的样子(也就是底部内容并没有位于窗口的底部,而留下了大量空白。
对于追未完美的设计师来说,这是不美观的。网上有一些解决方案,但会出现当改变窗口高度时,底部和正文重叠的BUG。尽管没有多少人会有事没事儿的去改变窗口高度,但设计嘛,追求的就是尽善尽美。
下面是我找到的一个比较完美的方法,来自国外的设计达人,纯CSS,可以实现:
当正文内容很少时,底部位于窗口最下面。当改变窗口高度时,不会出现重叠问题。
甚至,创造该CSS的人还专门成立一个网站介绍这个CSS底部布局方案。不知道他有没有去申请专利:)
代码写法
html代码:
说明:
使用这个布局的前提,就是footer要在总的div容器之外,footer使用一个层,其它所有内容使用一个总的层。如果确实需要到添加其它同级层,那这个同级层就必须使用position:absolute进行绝对定位。
CSS代码:
下面是主要的CSS代码,让你的底部可以位于窗口的最下面:
html,
body, #wrap {height: 100%;} body > #wrap {height: auto;
min-height: 100%;} #main {padding-bottom: 150px;} #footer
{position: relative; margin-top: -150px; height: 150px;
clear:both;}
说明:
需要注意的就是#main的padding值、footer的高度和负margin值,需要保持一致。
就是这么简单,不过还没完。如果你的主体是使用悬浮布局,还得解决一些浏览器的兼容问题,这里使用的重点是为了Goolge
Chrome。
对#main部份进行著名的Clearfix Hack:
.clearfix:after
{content: "."; display: block; height: 0; clear: both; visibility:
hidden;} .clearfix {display: inline-block;} * html .clearfix {
height: 1%;}.clearfix {display: block;}
注: 该方案测试于两栏悬浮布局,兼容各大主流浏览器,包括Google
Chrome。
相关文章推荐
- Exchange 451 4.4.0&nbs…
- 【原创】Mac os pip&nbs…
- 宏基 ACER A500/501&nbs…
- CSS Sprites : 样式表贴图定位 &nd…
- 20 个经典的 Ajax + CSS 表格
- CSS tips: rounded corners without images
- 微软企业库的 注入和依赖&nbs…
- linux下stray \357&nbs…
- 让footer固定在页面(视口)底部(CSS-Sticky-Footer)
- const int *pi与int&nbs…
- MATLAB中的 anova1()函数&nbs…
- NSUserdefaults 对象存储&nbs…
- 2013年chinajoy showgirl&nbs…
- KUbuntu AMD Radeon&nbs…
- struct device dev;&nbs…
- Maven Jetty Plugin&nbs…
- sql server中的 SET&nbs…
- 什么是CSS Sprites(图片合并)技…
- ubuntu12.04与VM Virtual&nbs…
- 【js javascript】判断ie6,向css…