当我们在写页面时经常会遇到页面内容少的时候,footer会戳在页面中间或什么?反正就是不在最底部显示,反正就是很难看,下面要讲的布局就是解决如何使元素粘住浏览器底部,
方法一:footer高度固定+绝对定位
html
<div class="dui-container"> <header>Header</header> <main>Content</main> <footer>Footer</footer> </div>
CSS
.dui-container{ position: relative; min-height: 100%; } main { padding-bottom: 100px; } header, footer{ line-height: 100px; height: 100px; } footer{ width: 100%; position: absolute; bottom: 0 }
方法二:在主体content上的下边距增加一个负值等于底部高度
html
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS
html, body { height: 100%; } main { min-height: 100%; padding-top: 100px; padding-bottom: 100px; margin-top: -100px; margin-bottom: -100px; } header, footer{ line-height: 100px; height: 100px; }
方法三:将页脚的margin-top设为负数
html
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS
main { min-height: 100%; padding-top: 100px; padding-bottom: 100px; } header, footer{ line-height: 100px; height: 100px; } header{ margin-bottom: -100px; } footer{ margin-top: -100px; }
方法四: 通过设置flex,将footer的margin-top设置为auto
html
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS
body{ display: flex; min-height: 100vh; flex-direction: column; } header,footer{ line-height: 100px; height: 100px; } footer{ margin-top: auto; }
方法五: 通过函数calc()计算内容的高度
html代码
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS代码
main{ min-height: calc(100vh - 200px); /* 这个200px是header和footer的高度 */ } header,footer{ height: 100px; line-height: 100px; }
方法六: 通过设置flexbox,将主体main设置为flex
html
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS代码
body{ display: flex; min-height: 100vh; flex-direction: column; } main{ flex: 1 }
方法七: 使用grid布局
Html代码
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS代码
html { height: 100%; } body { min-height: 100%; display: grid; grid-template-rows: auto 1fr auto; } .footer { grid-row-start: 3; grid-row-end: 4; }
方法八: display-*
html
<header>Header</header> <main>Content</main> <footer>Footer</footer>
CSS
body { min-height: 100%; display: table; width: 100%; } main { display: table-row; height: 100%; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
一 是的,CSS也有正则(阿门) CSS装逼两利器:矩阵和正则。 其实呢,我们也不必...
计时器 (Timer)可以制作 WML 卡片来使用 WML 的计时器功能。计时器的时间单位是...
1.先是从前端的角度去考虑,如何让safari浏览器兼容video,并支持播放(未找到解...
没想到 dreamweaver 的菜单排放是这么糟糕,记录一下我找了两天才找到选项... 查...
再做H5页面的时候,发现audio在手机端和微信端添加了autoplay以后还是不可以自动...
图灵平台是美团配送技术团队搭建的一站式算法平台,图灵平台中的在线服务框架—...
代码 div class=testdiv/divdiv/div/div .test{width: 200px;height: 200px;marg...
以前想实现一个圆角是比较麻烦的,不过现在CSS3来了,实现圆角变的那么的简单只...
自适应网页设计到底是怎么做到的?其实并不难。 一. 允许网页宽度自动调整: 首...
git是什么就不废话了 出现以下情况怎么解决? 有个 index.ts 文件 export const ...