


Summarize several methods of clearing floats in CSS and how to deal with compatibility
This article mainly introduces the summary and compatibility processing of the seven common methods of clearing floating floats in CSS. It is of great practical value. Friends in need can refer to it.
We need to understand two things before clearing floats. An important definition:
The definition of floating: Make the element break away from the document flow, move in the specified direction, and stop when it encounters the parent boundary or adjacent floating elements.
Height collapse: The height of the parent element of the floating element is adaptive (when the parent element does not write the height, and the child element writes the float, the height of the parent element will collapse)
After knowing floats and why they should be cleared, we can start to learn how to clear floats. At this time we need to use the attribute clear,
clear: left | right | both | none | inherit: a certain direction of the element There can be no floating elements on
clear:both: Floating elements are not allowed on the left and right sides.
There are several main ways to specify floating:
1. clear clear floating (add empty p method)
Add an empty p below the floating element and write css style to the element:
{clear:both;height:0;overflow:hidden;}
2. Method: Give the floating element a parent Level setting height
We know that the height collapse is caused by the adaptive height of the parent of the floating element, so we can solve this problem by setting an appropriate height for it.
Disadvantages: Not applicable when the height of the floating element is uncertain
3. Method: float (parent floats at the same time)
What does "floating to float" mean? That is to make the parent of the floating element also float.
Disadvantages: You need to add floats to the parent of each floating element. Too many floats can easily cause problems.
4. Method: Set the parent to inline-block
Disadvantages: The left and right margins of the parent are invalid and cannot be used. Margin: 0 auto; is centered
5. br clear float
<p class="box"> <p class="top"></p> <br clear="both" /> </p>
br tag has its own clear attribute. Setting it to both is actually the same as adding an empty p. the same.
Problem: It does not meet the requirements of separation of structure, style and behavior in work.
6. Add overflow:hidden clear float method to the parent;
Problem: Need to match the width or zoom to be compatible with IE6 IE7;
overflow: hidden; *zoom: 1;
7. Universal clearing method after pseudo-class clear floating (now the mainstream method, recommended)
选择符:after{ content:"."; clear:both; display:block; height:0; overflow:hidden; visibility:hidden; }
At the same time, in order to Compatible with IE6, 7 also needs to be used with zoom. For example:
.clear:after{content:'';display:block;clear:both;height:0;overflow:hidden;visibility:hidden;} .clear{zoom:1;}
Things to note:
after pseudo-class: add content at the end of the element;
:after{content"added content";} IE6 and 7 are not compatible
zoom zoom
a. Trigger haslayout under IE so that the element calculates the width and height based on its own content . b. FF is not supported;
The above is the detailed content of Summarize several methods of clearing floats in CSS and how to deal with compatibility. For more information, please follow other related articles on the PHP Chinese website!

The fact that anchor positioning eschews HTML source order is so CSS-y because it's another separation of concerns between content and presentation.

Article discusses CSS margin property, specifically "margin: 40px 100px 120px 80px", its application, and effects on webpage layout.

The article discusses CSS border properties, focusing on customization, best practices, and responsiveness. Main argument: border-radius is most effective for responsive designs.

The article discusses CSS background properties, their uses in enhancing website design, and common mistakes to avoid. Key focus is on responsive design using background-size.

Article discusses CSS HSL colors, their use in web design, and advantages over RGB. Main focus is on enhancing design and accessibility through intuitive color manipulation.

The article discusses the use of comments in CSS, detailing single-line and multi-line comment syntaxes. It argues that comments enhance code readability, maintainability, and collaboration, but may impact website performance if not managed properly.

The article discusses CSS Selectors, their types, and usage for styling HTML elements. It compares ID and class selectors and addresses performance issues with complex selectors.

The article discusses CSS priority, focusing on inline styles having the highest specificity. It explains specificity levels, overriding methods, and debugging tools for managing CSS conflicts.


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools

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

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

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),
