当其他元素居中对齐时,使用 Flexbox 将页脚与页面底部对齐
Posted
技术标签:
【中文标题】当其他元素居中对齐时,使用 Flexbox 将页脚与页面底部对齐【英文标题】:Align footer to bottom of page with Flexbox when another elements aligned center 【发布时间】:2021-06-24 00:20:57 【问题描述】:我找不到如何使用 flexbox 垂直对齐中心的 div 元素和对齐页面底部的页脚元素。
html 和 CSS
.section
height: 100vh;
display: flex;
align-items: center;
.container
width: 100%;
max-width: 1400px;
padding: 0 15px;
margin: 0 auto;
.section__header
text-align: center;
.footer
margin: auto;
max-width: 848px;
<section class="section contact">
<div class="container">
<div class="section__header">...</div>
<div class="contact__form">...</div>
<footer class="footer"></footer>
</div>
</section>
我尝试使用几乎所有选项都没有成功...所有我得到的 - 现在所有元素都水平和垂直居中,但是如何将页脚与底部对齐并将所有其他元素留在中心?
【问题讨论】:
【参考方案1】:*
padding: 0;
margin: 0;
box-sizing: border-box;
.section
display: flex;
height: 100vh;
justify-content: space-between;
flex-direction:column;
border:1px solid sienna;
.container
display:flex;
justify-content:center;
flex-direction:column;
width: 100%;
max-width: 1400px;
padding: 0 15px;
margin: 0 auto;
border:1px solid black;
.section__header
text-align: center;
border:1px solid maroon;
.contact__form
border:1px solid blue;
.footer
border:1px solid red;
<section class="section contact">
<div class="container">
<div class="section__header">header</div>
<div class="contact__form">contact</div>
</div>
<footer class="footer">footer</footer>
</section>
【讨论】:
【参考方案2】:<!DOCTYPE html>
<html lang="en">
<head>
<!-- ========== Meta Tags ========== -->
<meta charset="UTF-8">
<meta name="description" content="">
<meta name="keywords" content="">
<meta name="author" content="">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<!-- ========== Title ========== -->
<title>stack</title>
<style type="text/css">
*,
*:before,
*:after
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
-ms-box-sizing: border-box;
.section
height: 100vh;
width: 100%;
background: green;
.container
width: 100%;
height: 100%;
/*max-width: 1400px;*/
padding: 0 15px;
/*margin: 0 auto;*/
display: flex;
flex-direction: column;
justify-content: space-between;
background: blue;
.contentContainer
height: 80%;
width: 100%;
display: flex;
flex-direction: column;
justify-content: center;
background: green;
.section__header
/*text-align: center;*/
background: grey;
.contact__form
background: violet;
.footer
height: 20%;
width: 100%;
background: yellow;
/*margin: auto;*/
/*max-width: 848px;*/
</style>
</head>
<body>
<section class="section">
<div class="container">
<div class="contentContainer">
<div class="section__header">header</div>
<div class="contact__form">form</div>
</div>
<footer class="footer">footer</footer>
</div>
</section>
</body>
</html>
为内容创建一个单独的容器并使用space-between
。
【讨论】:
以上是关于当其他元素居中对齐时,使用 Flexbox 将页脚与页面底部对齐的主要内容,如果未能解决你的问题,请参考以下文章
将一个项目居中对齐,其他项目与 Flexbox 对齐 [重复]