CSS margin 折叠现象的实际代码示例

下面是展示 CSS margin 折叠现象的实际代码示例,包含了几种常见的 margin 折叠场景:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Margin Collapse Example</title>
    <style>
        /* 基础样式 */
        .container {
            width: 400px;
            margin: 20px auto;
            border: 1px solid #ccc;
            padding: 10px;
        }

        .box {
            height: 100px;
            background-color: #f0f0f0;
            border: 1px solid #999;
            text-align: center;
            line-height: 100px;
        }

        /* 1. 相邻兄弟元素的margin折叠 */
        .sibling1 {
            margin-bottom: 30px;
        }
        .sibling2 {
            margin-top: 20px;
            /* 实际间距是30px(取较大值),而不是50px */
        }

        /* 2. 父子元素的margin折叠(父元素没有padding/border隔离) */
        .parent {
            background-color: #e0e0e0;
            /* 取消注释可阻止折叠:
            padding: 1px; 
            或 border: 1px solid transparent;
            */
        }
        .child {
            margin-top: 20px;
            margin-bottom: 20px;
            /* 子元素的margin会"溢出"到父元素外 */
        }

        /* 3. 空元素的margin折叠 */
        .empty-box {
            margin-top: 20px;
            margin-bottom: 20px;
            /* 上下margin会折叠成一个20px的margin */
        }

        /* 4. 负margin的折叠情况 */
        .negative-sibling1 {
            margin-bottom: 30px;
        }
        .negative-sibling2 {
            margin-top: -10px;
            /* 实际间距是20px(30px + (-10px)) */
        }
    </style>
</head>
<body>
    <h2>1. 相邻兄弟元素的margin折叠</h2>
    <div class="container">
        <div class="box sibling1">下方margin: 30px</div>
        <div class="box sibling2">上方margin: 20px</div>
        <p>实际间距是30px(取较大值)</p>
    </div>

    <h2>2. 父子元素的margin折叠</h2>
    <div class="container">
        <div class="parent">
            <div class="box child">子元素上下margin: 20px</div>
        </div>
        <p>子元素的margin会溢出到父元素外(父元素无padding/border时)</p>
    </div>

    <h2>3. 空元素的margin折叠</h2>
    <div class="container">
        <div class="box">上方元素</div>
        <div class="empty-box"></div> <!-- 空元素 -->
        <div class="box">下方元素</div>
        <p>空元素的上下margin会折叠成一个margin</p>
    </div>

    <h2>4. 包含负margin的折叠</h2>
    <div class="container">
        <div class="box negative-sibling1">下方margin: 30px</div>
        <div class="box negative-sibling2">上方margin: -10px</div>
        <p>实际间距是20px(30px + (-10px))</p>
    </div>
</body>
</html>

代码说明:

  1. 相邻兄弟元素折叠:两个相邻元素的上下margin会合并,取较大的那个值(示例中30px覆盖20px)
  2. 父子元素折叠:当父元素没有padding、border或inline内容隔离时,子元素的margin会"溢出"到父元素外部
  3. 空元素折叠:没有内容、padding和border的空元素,其上下margin会合并为一个
  4. 负margin折叠:包含负margin时,最终间距为正margin与负margin的代数和

如何阻止margin折叠:

  • 给父元素添加padding或border
  • 使用BFC(块级格式化上下文),如给元素添加overflow: autodisplay: flex
  • 浮动元素(float不为none)不会产生margin折叠
  • 绝对定位元素的margin不会与其他元素折叠

运行这段代码可以直观看到各种margin折叠现象,以及它们的实际表现效果。

相关推荐
想吃火锅10055 小时前
【leetcode】405.数字转换为十六进制数js
开发语言·javascript·ecmascript
阿猫的故乡8 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
小和尚敲木头8 小时前
vue3 vite动态拼接图片路径
javascript
我叫黑大帅9 小时前
前端如何竖屏固定视口背景
前端·javascript·面试
不会敲代码19 小时前
我花了三天时间,终于把 Cookie、XSS、CSRF 和浏览器存储给整明白了
javascript·面试
贩卖黄昏的熊9 小时前
flex 布局快速梳理
开发语言·javascript·css3·html5
swipe9 小时前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试
kyriewen10 小时前
手写 call、apply、bind:从原理到实现,附 3 个最容易忽略的边界情况
前端·javascript·面试
胡萝卜术10 小时前
从内存视角重新认识 JavaScript 数据类型:一份深度学习笔记
前端·javascript·面试
LiuJun2Son10 小时前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js