浮动元素高度塌陷原因
我们经常会遇到一种情况,给一个元素设置浮动之后 float:left/right;如果父元素有一个边框,那么浮动元素无法将边框撑开。 如下图所示:
原因是因为元素浮动后,就脱离了文档流。那么它之前存在在父元素内的高度就随着浮动不复存在了,而此时父元素会默认自己里面没有任何内容。
浮动元素高度塌陷解决方法
1.给父元素设置高度
height:50px;
2.父元素设置浮动
.container{clear:both}
3.添加一个专用元素清除浮动
.clear{clear:both}
4.添加一个伪元素解决
.clearfix::after{
content:"";
display:block;
clear:both;
}
5.最简单的解决方案。 块级格式化上下文。BFC
.container {
overflow: hidden;
/*或 overflow: auto;*/
}
定位实现三列布局
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>定位实现三列布局</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
li {
list-style: none;
}
.header,
.footer {
height: 40px;
background-color: lightblue;
}
.content {
width: 1200px;
margin: 0 auto;
line-height: 40px;
}
.content p {
text-align: center;
}
.content ul li {
float: left;
line-height: 40px;
padding: 0 20px;
;
}
.content ul li:hover {
background-color: lightseagreen;
}
/*主体用绝对定位来做*/
.container {
width: 1200px;
margin: 10px auto;
background-color: mediumseagreen;
min-height: 600px;
position: relative;
}
.container>.left {
width: 200px;
min-height: 600px;
background-color: mediumslateblue;
position: absolute;
top: 0;
left: 0;
}
.container>.right {
width: 200px;
min-height: 600px;
background-color: mediumslateblue;
position: absolute;
top: 0;
right: 0;
}
.container>.main {
background-color: orangered;
min-height: 600px;
width: 800px;
position: absolute;
top: 0;
left: 200px;
}
</style>
</head>
<body>
<div class="header">
<div class="content">
<ul>
<li><a>首页</a></li>
<li><a>公司简介</a></li>
<li><a>联系我们</a></li>
</ul>
</div>
</div>
<div class="container">
<div class="left">左侧</div>
<div class="main">中间</div>
<div class="right">右侧</div>
</div>
<div class="footer">
<div class="content">
<p>xxx版权所有</p>
</p>
</div>
</div>
</body>
</html>
浮动技术实现三列布局
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>浮动实现三列布局</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
li {
list-style: none;
}
.header,
.footer {
height: 40px;
background-color: lightblue;
}
.content {
width: 1000px;
margin: 0 auto;
line-height: 40px;
}
.content p {
text-align: center;
}
.content ul li {
float: left;
line-height: 40px;
padding: 0 20px;
;
}
.content ul li:hover {
background-color: lightseagreen;
}
/*主体用绝对定位来做*/
.container {
width: 1000px;
margin: 10px auto;
background-color: mediumseagreen;
min-height: 600px;
overflow: hidden;
}
.container>.left {
width: 200px;
min-height: 600px;
background-color: mediumslateblue;
float: left;
}
.container>.right {
width: 200px;
min-height: 600px;
background-color: mediumslateblue;
float: right;
}
.container>.main {
background-color: orangered;
min-height: 600px;
width: 560px;
margin-left: 20px;
margin-right: 20px;
float: left;
}
</style>
</head>
<body>
<div class="header">
<div class="content">
<ul>
<li><a>首页</a></li>
<li><a>公司简介</a></li>
<li><a>联系我们</a></li>
</ul>
</div>
</div>
<div class="container">
<div class="left">左侧</div>
<div class="main">中间</div>
<div class="right">右侧</div>
</div>
<div class="footer">
<div class="content">
<p>xxx版权所有</p>
</p>
</div>
</div>
</body>
</html>
总结
- 解决浮动元素高度塌陷,用第5种方法,更方便。
- 三列布局的实现方法有很多,定位和浮动是基础的,还有Flex布局,网格布局等。以后掌握了再纪录!