[css]margin-top不起作用问题(外边距合并)

news/2024/7/7 22:54:15

在初学css时,会遇到突然间margin-top不起作用的情况。如下面:
情况一:
代码:

<html>
<head>

<style type="text/css">
* {
  margin:0;
  padding:0;
  border:0;
}

#outer {
  width:300px;
  height:300px;
  background-color:red;
}

#inner {
  width:50px;
  height:50px;
  background-color:blue;
  margin-top:20px;
}

</style>
</head>

<body>

<div id="outer">
  <div id="inner">
  </div>
</div>

</body>
</html>

根据以上代码推测,理想的状态下应该是outer元素外边距top是0,inner元素相对outer有一个20px的外边距top:20px。但是,看下面结果。

效果图:
明明只给inner元素设置了外边距: margin-top:20px;,而outer元素也跟着设置了外边距top:20px。
在这里插入图片描述
情况二:
代码:

<html>
<head>

<style type="text/css">
* {
  margin:0;
  padding:0;
  border:0;
}

#father {
  width:300px;
  height:300px;
  background-color:red;
  margin-bottom:50px;
}

#sun {
  width:50px;
  height:50px;
  background-color:blue;
  margin-top:20px;
}

</style>
</head>

<body>

<div id="father">
 
</div>
 <div id="sun">
  </div>

</body>
</html>

理想的效果应该是father元素和sun元素之间的间距应该为20px+50px。但是结果是:50px,效果图如下:
在这里插入图片描述
上面的情况一叫做外边距塌陷,情况二叫做外边距合并
外边距塌陷:两个嵌套关系的(父子关系)块元素,当父元素有上外边距或者没有上外边距(margin-top),子元素也是有上外边距的时候。两个上外边距合并成一个上外边距,以值较大的上外边距值为准。
外边距合并指的是,当两个垂直外边距相遇时,它们将形成一个外边距。合并后的外边距的高度等于两个发生合并的外边距的高度中的较大者。

外边距塌陷解决办法:
1、给父元素设置外边框border或者设置内边距padding
示例:以情况一为示例
代码:

<html>
<head>

<style type="text/css">
* {
  margin:0;
  padding:0;
  border:0;
}

#outer {
  width:300px;
  height:300px;
  background-color:red;
  border:1px solid #202124;
}

#inner {
  width:50px;
  height:50px;
  background-color:blue;
  margin-top:20px;
}

</style>
</head>

<body>

<div id="outer">
  <div id="inner">
  </div>
</div>

</body>
</html>

给outer元素添加: border:2px solid #202124
效果图:
在这里插入图片描述
2、触发BFC
BFC:Block Formatting Context,块级格式化上下文。在outer元素中添加overflow:hidden。

<html>
<head>

<style type="text/css">
* {
  margin:0;
  padding:0;
  border:0;
}

#outer {
  width:300px;
  height:300px;
  background-color:red;
 overflow:hidden
}

#inner {
  width:50px;
  height:50px;
  background-color:blue;
  margin-top:20px;
}

</style>
</head>

<body>

<div id="outer">
  <div id="inner">
  </div>
</div>

</body>
</html>

效果图:
在这里插入图片描述
外边距合并问题解决:
1、只给其中一个元素设置margin值就行
2、给每个元素添加父元素,将外边距合并问题转化为外边距塌陷问题,然后用解决外边距塌陷问题办法去解决,这样就完美解决问题。这个思路有点意思。转化问题,在解决。

现在来讨论一下外边距合并问题带来的好处:
w3school中举个例子:
外边距合并初看上去可能有点奇怪,但是实际上,它是有意义的。以由几个段落组成的典型文本页面为例。第一个段落上面的空间等于段落的上外边距。如果没有外边距合并,后续所有段落之间的外边距都将是相邻上外边距和下外边距的和。这意味着段落之间的空间是页面顶部的两倍。如果发生外边距合并,段落之间的上外边距和下外边距就合并在一起,这样各处的距离就一致了。
在这里插入图片描述


http://lihuaxi.xjx100.cn/news/1396528.html

相关文章

安卓手机免root本地运行青龙面板(ZeroTermux)

安卓手机免root本地运行青龙面板 网盘下载&#xff1a; https://www.123pan.com/s/EZ6KVv-J41Gd.html提取码:4444 ZeroTermux&#xff1a;https://od.ixcmstudio.cn/repository/main/ZeroTermux/ 青龙面板APP&#xff1a; https://gitee.com/wsfsp4/QingLong/releases MT管…

九十九回 如何实现文件存储一

文章目录 概念介绍实现方法示例代码 我们在上一章回中介绍了"如何实现本地存储"相关的内容&#xff0c;本章回中将介绍 如何实现文件存储.闲话休提&#xff0c;让我们一起Talk Flutter吧。 概念介绍 我们在上一章回中介绍的本地存储只能存储dart语言中基本类型的数…

死锁产生的原因及解决方案

死锁 1. 死锁的成因2. 解决方案 1. 死锁的成因 互斥条件: 一个资源每次只能被一个进程使用。请求与保持条件&#xff1a;一个进程因请求资源而阻塞时&#xff0c;对已获得的资源保持不放。不可剥夺条件:进程已获得的资源&#xff0c;在末使用完之前&#xff0c;不能强行剥夺。…

【LeetCode 算法】Reorder List 重排链表

文章目录 Reorder List 重排链表问题描述&#xff1a;分析代码PointerReverseMerge Tag Reorder List 重排链表 问题描述&#xff1a; 给定一个单链表 L 的头节点 head &#xff0c;单链表 L 表示为&#xff1a; L0 → L1 → … → Ln - 1 → Ln 请将其重新排列后变为&#…

js实现节流函数,当需要对一个高频触发的事件进行节流时,可以使用节流函数来限制事件的触发频率

当需要对一个高频触发的事件进行节流时&#xff0c;可以使用节流函数来限制事件的触发频率 function throttle(func, delay) {let timeoutId;return function() {if (!timeoutId) {timeoutId setTimeout(() > {func.apply(this, arguments);timeoutId null;}, delay);}};…

virbr是什么设备

virbr是什么设备 virbr是一个虚拟桥接网络设备&#xff0c;通常由虚拟机管理程序&#xff08;如 KVM、VirtualBox 或者 libvirt 等&#xff09;创建和管理。它用于在宿主机和虚拟机之间进行网络连接&#xff0c;以便虚拟机可以通过宿主机访问网络。 默认情况&#xff0c;libv…

嵌入式面试常见题目收藏(超总结)

​ 这篇文章来自很多博客主和其他网站的作者&#xff0c;如有侵权&#xff0c;联系必删 文章出处标注&#xff1a; https://blog.csdn.net/qq_44330858/article/details/128947083 ***如需PDF或者原稿可私信 *** ***如需PDF或者原稿可私信 *** ***如需PDF或者原稿可私信 *** 1.…

配置uniapp 的保姆级代码,拿来就能用!

闲下来整理一下最近使用uniapp遇到的问题。之前我开发的时候用的是vue2.0&#xff0c;uniapp有 uview2.x ui组件&#xff0c;后来又开发新项目使用了vue3.0 但是对UI的要求 uview2.x 不满足&#xff0c;还好后来又出了一个 uview-plus3.x(vue3)这个甚合心意呀&#xff0c;使用…