


Css collapses margin
a. Let’s first look at the w3c document’s definition of margin collapse:
In CSS, the adjoining margins of two or more boxes (which might or might not be siblings) can combine to form a single margin. Margins that combine this way are said to collapse, and the resulting combined margin is called a collapsed margin.
Translation: in In CSS, the margins of adjacent boxes (which may or may not be sibling elements) can be combined into one margin. This merging of margins is called Collapse, and this merged margin is called Collapsed margins.
For example:
<style type="text/css">.testBFC{ width:100px; height:100px; background-color:green;}.testBFC div{ width:30px; height:30px; background-color:pink; }.testBFC div:first-child{ margin-bottom:10px;}.testBFC div:last-child{ margin-top:10px;}</style><div class="testBFC"> <div>div1</div> <div>div2</div></div>
The running result is as shown below. We can see from the picture that the margin-bottom of div1 and the margin-top of div2 are merged. As a result, there is only 10px between div1 and div2. We originally wanted them to be 20px apart. How to achieve this? You can add: display: inline-block to the class of div1. This involves how to solve or avoid the problem of margin collapse.
Let’s take a look at the specific notes in the w3c document:
Note the above rules imply that:
1. Floating boxes will not collapse between other boxes. (Folding will not occur even between a floating box and its normal flow child elements). For example, in the following example, the outer edge will collapse between the parent element and the child element. In this case, it can be set by the parent element or the child element. If it becomes floating, it will display normally.
<head> <style type="text/css"> *{ margin:0; padding:0; } .testBFC{ width:100px; height:100px; background-color:green; margin-top:10px; } .testBFC div{ width:30px; height:30px; background-color:pink; } .testBFC div:first-child{ margin-top:10px; } </style></head><body><div class="testBFC"> <div>div1</div></div></body>
2. Create a new block formatting context (block-level formatting context) for the element's margins, so that it will not conflict with its normal Child elements in the flow are collapsed. As in the above example, you can add an attribute overflow:hidden
3 to the outer div. Absolutely positioned boxes will not collapse. In the above example, you can add attributes to the parent element or child element: position:absolute or fixed.
4. In a normal document flow, the bottom margin of the block-level element is equal to the one behind it. The top margin of sibling elements collapses unless you set clearance. See example at top of article.
5. The top margin of a block-level element will collapse with the top margin of its child element of the first block-level element. If this block-level element does not set top border, no top padding, the child The element does not have clearance. Example: This example is already in tip 1.
6. The bottom margin of a block-level element may collapse with the bottom margin of its last block-level child element. If this block-level element does not set bottom padding, bottom border and height:auto , min-height:0
7. Such a box will collapse the margins, min-height:0, and there is no top or bottom borders or top or bottom padding set, and height:0 or auto and it does not Contains the line box and collapses the margins of all its child elements.
For detailed information, please refer to the w3c document: http://www.w3.org/TR/CSS2/box.html#collapsing-margins

The article discusses the HTML <datalist> element, which enhances forms by providing autocomplete suggestions, improving user experience and reducing errors.Character count: 159

The article discusses using HTML5 form validation attributes like required, pattern, min, max, and length limits to validate user input directly in the browser.

The article discusses the HTML <progress> element, its purpose, styling, and differences from the <meter> element. The main focus is on using <progress> for task completion and <meter> for stati

Article discusses best practices for ensuring HTML5 cross-browser compatibility, focusing on feature detection, progressive enhancement, and testing methods.

The article discusses the <iframe> tag's purpose in embedding external content into webpages, its common uses, security risks, and alternatives like object tags and APIs.

The article discusses the HTML <meter> element, used for displaying scalar or fractional values within a range, and its common applications in web development. It differentiates <meter> from <progress> and ex

The article discusses the viewport meta tag, essential for responsive web design on mobile devices. It explains how proper use ensures optimal content scaling and user interaction, while misuse can lead to design and accessibility issues.

This article explains the HTML5 <time> element for semantic date/time representation. It emphasizes the importance of the datetime attribute for machine readability (ISO 8601 format) alongside human-readable text, boosting accessibilit


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Zend Studio 13.0.1
Powerful PHP integrated development environment

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.
