复制代码代码如下:
<style type="text/css">
*{margin:0;padding:0;}
p{border: 1px #66CC00 solid;}
img {
width:40px;
height:40px;
float:left;
border: 1px #66CC00 solid;
}
h3{
clear:both;
border: 1px #66CC00 solid;
}
div{padding:20px;width:400px;height:400px;}
</style>
</head>
<body>
<div>
<p>我在上面</p>
<img src="/UploadFiles/2021-03-30/QQ截图未命名.png"><h3>我在下面</h3>
</div>
效果:
data:image/s3,"s3://crabby-images/a2e82/a2e828092c86805a960dba4653b7105830198fc8" alt="css clear之清除区域"
为h3设置margin-top试试:
复制代码代码如下:
h3{
clear:both;
border: 1px #66CC00 solid;
margin-top:30px;
}
来看看效果:
data:image/s3,"s3://crabby-images/a2e82/a2e828092c86805a960dba4653b7105830198fc8" alt="css clear之清除区域"
没有变化,清除区域在起作用了,改变一下:
复制代码代码如下:
h3{
clear:both;
border: 1px #66CC00 solid;
margin-top:60px;
}
效果:
data:image/s3,"s3://crabby-images/53f75/53f75ca74db8a38aa525acc6aec27fe41fb279be" alt="css clear之清除区域"
有了16px的间距了,我们可以理解这个margin是相对于“我在上面”计算的,其实是这个清除区域在作怪,我们可以简单的设置一下:
复制代码代码如下:
<style type="text/css">
*{margin:0;padding:0;}
p{border: 1px #66CC00 solid;}
img {
width:40px;
height:40px;
float:left;
border: 1px #66CC00 solid;
margin-bottom:20px;
}
h3{
clear:both;
border: 1px #66CC00 solid;
}
div{padding:20px;width:400px;height:400px;}
</style>
</head>
<body>
<div>
<p>我在上面</p>
<img src="/UploadFiles/2021-03-30/QQ截图未命名.png"><h3>我在下面</h3>
</div>
效果:
data:image/s3,"s3://crabby-images/58a9b/58a9bd87d47e51b58e829f724bd7223c49f606ea" alt="css clear之清除区域"
效果理想!
为浮动元素设置外边距,而不为“我在下面”(清除元素)设置上外边距,问题就解决了!