码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • CSS -- Margin Collapsing


    Mastering margin collapsing - CSS: Cascading Style Sheets | MDNThe top and bottom margins of blocks are sometimes combined (collapsed) into a single margin whose size is the largest of the individual margins (or just one of them, if they are equal), a behavior known as margin collapsing. Note that the margins of floating and absolutely positioned elements never collapse.https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Box_Model/Mastering_margin_collapsing

    The Rules of Margin Collapsehttps://www.joshwcomeau.com/css/rules-of-margin-collapse/

    Definition: Elements' top and bottom margins are sometimes collapsed into a single margin that is equal to the larger of the two margins.

    • Rule1: Only vertical margins collapse
    • Rule2: Only adjacent elements collapse
    • Rule3: The Bigger Margin Wins
    • Rule4: Nesting doesn't prevent collapsing
      • Because the parent's margin can absorb/transfer child's margin
      • Unless .... (Rule 4.1)
      • There is another elements in-between the parent and child element

      • The parent element have a height set.

      • The parent element have padding or border along the relevant edge.

    • Rule5: Margins can collapse in the same direction

    • And many more ... (see links above)

    ** Margins of floating and absolutely positioned elements never collapse.

    Example:

            

    • yomama & yopapa are two boxes stacked vertically (Rule #1) on top of one another (Rule #2)
      • bottom margin for yomama is 20px
      • top margin for yopapa is 10px

            

    • When we inspect yomama, its bottom margin is clearly touching the yopapa box, indicating that the margins are collapsed  

             

    • When we inspect yopapa, its top margin is 10px, which is still 10px away from the yomama

            

    • When the larger margin collapse with a smaller margin, the larger margin wins, in this case, the combined margin has the width of 20px. yomama wins! (Rule #3)
    • Then, we add an extra nesting around yomama -- throw yomama in a <div>!

                    

    • Nothing really happens (Rule#4) beacuse instead of applying this margin between yomama and the parent <div>, the margin is directly transfered to the div, i.e. between div and yopapa.
    • However, we can add some padding, or set a height for the parent div to prevent collapsing (Rule #4.1)
      • Set height
        • We set the height of the parent div to 90px to make space for the yomama margin
      • Add padding (extra space between content -- i.e. children -- and border)
        • We added 10px padding (the green bar) at the bottom to prevent the margin being transfered to the div box, instead, we add 10px to the original 20px margin to keep them apart.
  • 相关阅读:
    MySQL事务——事务隔离界别,MVCC
    【每天一道算法题】day2-认识时间复杂度
    VirtualBox VMs 扩展磁盘空间
    Arrays.asList()的那些坑
    论文阅读——BART
    逍遥自在学C语言 | 逻辑运算符
    oracle 与mysql兼容日期(格式:YYYY年MM月DD日)
    SpringBoot+Vue甘肃非物质文化网站(前后端分离)
    01-了解微服务架构的演变过程和微服务技术栈
    R与Python:编程语言间的差异与魅力
  • 原文地址:https://blog.csdn.net/DOITJT/article/details/125532721
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号