CSS Sticky Footer
来源:互联网 发布:淘宝详情页图片尺寸 编辑:程序博客网 时间:2024/05/22 16:39
CSS的简单在于它易学,CSS的困难在于寻找更好的解决方案。在CSS的世界里,似乎没有完美这种说法。所以,现在介绍的CSS绝对底部,只是目前个人见过的方案中比较完美的吧。
先说我们为什么会使用到这个CSS底部布局解决方案:
当做一个页面时,如果页面内容很少,不足于填充一屏的窗口区域,按普通的布局,就会出现下面图片中的样子(也就是底部内容并没有位于窗口的底部,而留下了大量空白。
对于追未完美的设计师来说,这是不美观的。网上有一些解决方案,但会出现当改变窗口高度时,底部和正文重叠的BUG。尽管没有多少人会有事没事儿的去改变窗口高度,但设计嘛,追求的就是尽善尽美。
下面是我找到的一个比较完美的方法,来自国外的设计达人,纯CSS,可以实现: 当正文内容很少时,底部位于窗口最下面。当改变窗口高度时,不会出现重叠问题。
甚至,创造该CSS的人还专门成立一个网站介绍这个CSS底部布局方案。不知道他有没有去申请专利:)
代码写法
HTML代码
<body> <div id="wrap"> <div id="main" class="clearfix"> <div class="content"></div> <div id="side"></div> </div> </div> <div id="footer">哈哈哈</div></body>
说明: 使用这个布局的前提,就是footer要在总的div容器之外,footer使用一个层,其它所有内容使用一个总的层。如果确实需要到添加其它同级层,那这个同级层就必须使用position:absolute进行绝对定位。
CSS代码
下面是主要的CSS代码,让你的底部可以位于窗口的最下面:
html, body{ 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值,需要保持一致。
这里我来说明一下我对这段代码的理解
首先, 将html、body和wrap的高度都设置成100%, 作用是为了让wrap的高度撑大, 达到整个屏幕的垂直方向的分辨率. 此时屏幕上所有的内容都是wrap的内容, 而footer的内容就被挤到下面去了, 只有滑动滚动条才可以看见.
接着给footer设置margin-top, 并且为footer的高度的负数, 这样就可以把footer往上拉, 重新回到可视区, 并且在屏幕的最下面.
此时当wrap的内容组件变多, 多到屏幕已经放不下的时候, footer会把wrap里面最下面的150px的内容给遮盖掉. 为了防止这种现象发生, 给wrap里面的内容主体main添加padding-bottom: 150px这里的值必须跟footer的高度相等, 这样就给main的下方留出一片空白, 这样即便被footer遮挡了, 遮挡的部分也只是背景, 没有内容, 这样就能实现最开始提出的那种效果了!!
转载自:
http://paranimage.com/css-sticky-footer/
- css sticky footer
- CSS sticky footer
- CSS Sticky Footer 布局
- CSS Sticky Footer
- CSS Sticky Footer
- CSS Sticky Footer布局
- css sticky footer布局
- css sticky footer
- css sticky footer布局
- CSS Sticky footer布局
- Css Sticky footer布局
- Sticky Footer: 完美的CSS绝对底部
- Sticky Footer: 完美的CSS绝对底部
- css sticky footer布局+流式布局
- CSS Sticky footer完美底部布局
- CSS 万能的 sticky-footer 写法
- Sticky Footer
- sticky footer
- 记一次ThinkPHP源码审计
- SQL Server 访问发送Http请求
- 字符串分割--java中String.split()用法
- python3使用正则爬取妹子图
- ubuntu的Linux安装svn并部署项目,同时实现项目同步更新(本地提交commit,项目目录自动更新)
- CSS Sticky Footer
- Android统计表格MPAndroidChart解析
- Spring Security(19)——对Acl的支持
- 关于对象的中间获取时,内存获取修改的问题
- JSLint的使用与安装
- 九度OJ 1015 还是A+B
- 单独编译和使用webrtc音频降噪模块(NS)
- 多态
- Zookeeper集群环境安装过程详解