Home Web Front-end Front-end Q&A What are the ways to clear floats in css

What are the ways to clear floats in css

Oct 30, 2023 am 11:57 AM
css clear float

The ways to clear floats in css include using the clear attribute, overflow attribute, clearfix class, parent element's clearfix class, pseudo-element to clear float, parent element's overflow attribute, and clear attribute combined with BFC. Detailed introduction: 1. Use the clear attribute, a simple and commonly used method to clear floats. By adding an empty block-level element after the floating element and setting the clear attribute for it, you can clear the previous floating effect and make it The elements below are laid out normally and so on.

What are the ways to clear floats in css

The operating system for this tutorial: Windows 10 system, DELL G3 computer.

In CSS, float is a common layout technique that allows an element to break out of the normal document flow and float along the left or right side of its container. However, when floated elements have different heights or there is overlap between floated elements, it can cause layout confusion or unexpected side effects. To solve these problems, we can use different ways to clear floats. Below I will introduce some commonly used CSS methods to clear floats.

1. Use the clear attribute:

The clear attribute is a simple and commonly used method to clear floats. By adding an empty block-level element after a floating element and setting the clear attribute, the effect of the previous floating element can be cleared and the elements below it can be laid out normally. The clear attribute can be set to left, right, both, or none, which means clearing left floats, right floats, clearing left and right floats at the same time, or not clearing floats respectively.

Sample code:

   .clearfix::after {
     content: "";
     display: block;
     clear: both;
   }

Sample HTML code:

   <div class="clearfix">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

2. Use the overflow attribute:

The overflow attribute is another commonly used method to clear floats method. By setting the overflow attribute to auto or hidden on the container of a floating element, you can trigger the BFC (block-level formatting context), thereby clearing the effect of floating. This is because BFC will include floating elements and calculate their height so that the container can be laid out normally.

Sample code:

   .clearfix {
     overflow: hidden;
   }

Sample HTML code:

   <div class="clearfix">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

3. Use the clearfix class:

The clearfix class is a commonly used class for clearing floats Name, you can clear the floating effect by adding the clearfix class to the container of the floating element. This method usually uses the pseudo-class::after to add an empty block-level element and set the clear attribute for it.

Sample code:

   .clearfix::after {
     content: "";
     display: block;
     clear: both;
   }
   .clearfix {
     zoom: 1;
   }

Sample HTML code:

   <div class="clearfix">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

4. Use the clearfix class of the parent element:

In some cases, we can Add the clearfix class directly to the parent element of the floating element to clear the floating effect. This method is similar to the above-mentioned clearfix class method, but adding the clearfix class to the parent element can more conveniently clear the floating effect of all child elements.

Sample code:

   .parent-element::after {
     content: "";
     display: block;
     clear: both;
   }

Sample HTML code:

   <div class="parent-element clearfix">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

5. Use pseudo elements to clear floats:

In addition to using the pseudo class::after , we can also use pseudo-element::before to clear floats. By adding an empty block-level element to the floating element's container and setting its content attribute to an empty string, BFC can be triggered to clear the floating effect.

Sample code:

   .clearfix::before,
   .clearfix::after {
     content: "";
     display: table;
   }
   .clearfix::after {
     clear: both;
   }
   .clearfix {
     zoom: 1;
   }

Sample HTML code:

   <div class="clearfix">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

6. Use the overflow attribute of the parent element:

In addition to setting it on the container of the floating element In addition to the overflow attribute, we can also set the overflow attribute on its parent element to clear the floating effect. This method is similar to the overflow attribute method mentioned above, but setting the overflow attribute on the parent element makes it easier to clear the floating effect of all child elements.

Sample code:

   .parent-element {
     overflow: hidden;
   }

Sample HTML code:

   <div class="parent-element">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

7. Using the clear attribute and BFC:

In some cases, we can pass Combine the clear attribute with BFC to clear floats. By adding an empty block-level element after the floating element, setting the clear attribute for it, and then setting the overflow attribute of the container of the floating element to auto or hidden, you can use these two methods at the same time to clear the floating effect.

Sample code:

   .clearfix::after {
     content: "";
     display: block;
     clear: both;
   }
   .clearfix {
     overflow: hidden;
   }

Sample HTML code:

   <div class="clearfix">
     <div class="float-left">左浮动元素</div>
     <div class="float-right">右浮动元素</div>
   </div>

In summary, CSS ways to clear floats include using the clear attribute, overflow attribute, clearfix class, and parent element The clearfix class, pseudo-element clear float, the overflow attribute of the parent element, and the combination of the clear attribute and BFC methods. In actual development, we can choose an appropriate method to clear floats based on specific needs and layout conditions to ensure that the layout of the page is correct and in line with expectations.

The above is the detailed content of What are the ways to clear floats in css. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to create a dotted border in CSS How to create a dotted border in CSS Aug 15, 2025 am 04:56 AM

Use CSS to create dotted borders, just set the border attribute to dotted. For example, "border:3pxdotted#000" can add a 3-pixel-wide black dot border to the element. By adjusting the border-width, the size of the point can be changed. The wider borders produce larger points. You can set dotted borders for a certain side, such as "border-top:2pxdottedred". Dotted borders are suitable for block-level elements such as div and input. They are often used in focus states or editable areas to improve accessibility. Pay attention to color contrast. At the same time, different from dashed's short-line style, dotted presents a circular dot shape. This feature is widely used in all mainstream browsers.

How to use CSS gradients for backgrounds How to use CSS gradients for backgrounds Aug 17, 2025 am 08:39 AM

CSSgradientsprovidesmoothcolortransitionswithoutimages.1.Lineargradientstransitioncolorsalongastraightlineusingdirectionsliketobottomorangleslike45deg,andsupportmultiplecolorstopsforcomplexeffects.2.Radialgradientsradiatefromacentralpointusingcircleo

How to create a glassmorphism effect with CSS How to create a glassmorphism effect with CSS Aug 22, 2025 am 07:54 AM

To create a glass mimicry effect of CSS, you need to use backdrop-filter to achieve background blur, set a translucent background such as rgba(255,255,255,0.1), add subtle borders and shadows to enhance the sense of hierarchy, and ensure that there is enough visual content behind the elements; 1. Use backdrop-filter:blur(10px) to blur the background content; 2. Use rgba or hsla to define the transparent background to control the degree of transparency; 3. Add 1pxsolidrgba(255,255,255,0.3) borders and box-shadow to enhance the three-dimensionality; 4. Ensure that the container has rich backgrounds such as pictures or textures to present a blurred penetration effect; 5. It is compatible with old browsers

How to change the list style in CSS How to change the list style in CSS Aug 17, 2025 am 10:04 AM

To change the CSS list style, first use list-style-type to change the bullet or numbering style. 1. Use list-style-type to set the bullet of ul to disc, circle or square, and the number of ol is decimal, lower-alpha, upper-alpha, lower-roman or upper-roman. 2. Remove the tag completely with list-style:none. 3. Use list-style-image:url('bullet.png') to replace it with a custom image. 4. Use list-style-position:in

How to implement a dark mode theme with CSS How to implement a dark mode theme with CSS Aug 22, 2025 am 09:55 AM

There are two main ways to implement dark mode: one is to use prefers-color-scheme media to query automatically to adapt system preferences, and the other is to add manual switching function through JavaScript. 1. Use prefers-color-scheme to automatically apply dark themes according to the user system. There is no need for JavaScript, just define the styles in the media query; 2. To achieve manual switching, you need to define light-theme and dark-themeCSS classes, add toggle buttons, and use JavaScript to manage the theme status and localStorage to save user preferences; 3. You can combine both to read localSt first when the page is loaded.

How to change the cursor in CSS How to change the cursor in CSS Aug 16, 2025 am 05:00 AM

Usebuilt-incursortypeslikepointer,help,ornot-allowedtoprovideimmediatevisualfeedbackfordifferentinteractiveelements.2.ApplycustomcursorimageswiththecursorpropertyusingaURL,optionallyspecifyingahotspotandalwaysincludingafallbacklikeautoorpointer.3.Fol

How to use grid-template-areas in CSS How to use grid-template-areas in CSS Aug 22, 2025 am 07:56 AM

Thegrid-template-areaspropertyallowsdeveloperstocreateintuitive,readablelayoutsbydefiningnamedgridareas;eachstringrepresentsarowandeachwordacolumncell,withgrid-areanamesonchildelementsmatchingthoseinthetemplate,suchas"headerheaderheader"for

How to style ordered and unordered lists with CSS How to style ordered and unordered lists with CSS Aug 22, 2025 am 07:59 AM

CSSallowsfullcustomizationoforderedandunorderedliststoenhancereadabilityanddesignconsistency.Youcanchangedefaultmarkersusingthelist-style-typeproperty,suchassettingunorderedliststousesquare,circle,ornobullets,andorderedliststousenumberingstyleslikede

See all articles