西北马二最代码的gravatar头像
西北马二最代码 2016-09-20 11:20:42
css绝对底部的较良解决方案

Css Sticty Footer:Css绝对底部的较好实现

一、为什么?
当做一个页面时,如果页面内容很少,不足于填充一屏的窗口区域,按普通的布局,底部内容就无法占据窗口的底部,而在整个页面显示上留下了大量空白。

二、介绍:
接下来学习的内容是一位国外的设计达人写的用纯Css实现的绝对底部方案,其功能异常强大,当页面内容不足时,底部也可以安分的待在自己的最下端,当内容的宽度被改变时,底部也不会影响到内容的显示。

三、
接下来我们直接进行这位牛人的代码部分的学习:

<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代码部分:

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的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。

P.S:

网络上之前比较知名的footer布局有Ryan Faits创造的,不过它的方法在HTML代码中会有一个空的div层。严格来说,是不符合语义网代码标准的。
另外,还有一篇Exploring Footers article from A List Apart,但使用了一些JavaScript代码。
这样一比较,上面看似简单的纯CSS,就显得伟大许多了。
OK, 没有了。如果没看懂,具体的使用方法和说明可以到原站查看。


打赏
最近浏览
youwuzuichen  LV10 2019年10月5日
Devil2020 2019年5月22日
暂无贡献等级
203778513  LV9 2017年9月13日
温柔的小白  LV8 2017年8月24日
gd19930626  LV4 2017年3月1日
嘻嘻~  LV7 2017年2月24日
zxc789  LV2 2016年10月24日
阳光和煦ing  LV2 2016年10月12日
cinwell  LV2 2016年10月11日
xiaoxiao111  LV1 2016年10月11日
顶部 客服 微信二维码 底部
>扫描二维码关注最代码为好友扫描二维码关注最代码为好友