It is believed that many front-end designers use floating layouts for page design, which takes elements out of the flow of the document. In the document flow, the parent element will default to the quilt element, and once the child element is set to float completely out of the document flow, the child element will not be able to support the height of the parent element, resulting in the parent element height collapse problem. Below xiao Bai will introduce several common ways to clear float.

What is height collapse of parent element

We have mentioned the reasons for the height collapse problem of the parent element, so let’s first understand what is the height collapse problem of the parent element. (Directly to the code)

HTML DOM structure code:

<body>
   <div class="parent-box">
   <div class="son-box"></div>   
   </div>
   <div class="another-box"></div>
<body>
Copy the code

CSS styles

<style>    . {      margin: 0;      padding: 0;    }    .parent-box {      width: 200px;      background: gray;      border: 5px solid;    }    .son-box {      width: 100px;      height: 100px;      background: blue;    }    .another-box {      width: 100px;      height: 100px;      background: greenyellow;    }  </style>
Copy the code

The effect is as follows:

Add the float: right property to the son-box and float it to the right.

But the actual result looks like this:

This is the problem of height collapse, where the height collapse causes the element below the parent element to move up, overtaking the place of the parent element, which is the last thing we want. Whenever the child element completely falls out of the document flow, the parent element height collapses.

Two, clear floating method (to solve the height problem)

So how to solve it, the following small white on the introduction of several clear floating methods.

By enabling (BFC) block-level formatting context (Overfloat: hidden; zoom : 1 ; )

According to W3C standards, elements on a page have an implicit property called Block Formatting Context (BFC). This property can be turned on or off, and is turned off by default.

Once the ELEMENT’s BFC is enabled, the element will have the following properties:

  1. The vertical margin of the parent element does not overlap the child element
  2. Elements with BFC enabled are not overwritten by floating elements
  3. Elements that enable BFC can contain floating child elements

How to turn on element BFC:

  1. Float element: Does not solve height collapse, but causes height collapse
  2. Set the absolute positioning of elements: ditto
  3. Setting the element to inline-block resolves the height collapse problem but causes the parent element to lose width. This is not recommended
  4. Set the element’s overfloat property to a non-visible value: Hidden is recommended as this is the least harmful way to turn on the BFC; But this will hide the overflow content, depending on the situation

However, IE6 and below browsers do not support BFC, so using this method is not compatible with some browsers. However, in IE6, although BFC is not supported, there is another hidden attribute called hasLayout. The function of this attribute is similar to BFC, and there are many ways to open it. Here is not a list. Can. The specific code is as follows:

.parent-box{ width: 200px; background: gray; border: 5px solid; overflow: hidden; zoom: 1; }Copy the code

Add an empty div element after the parent element of the height collapse

This is the easiest way to solve the height collapse problem. Simply add an empty div to the end of the parent element and set the clear: both attribute. Since the empty div is not floating, the height of the parent element can be enlarged without any side effects. However, redundant structure will be added to the page and is not recommended. The specific code is as follows:

<body> <div class="parent-box"> <div class="son-box"></div> <div style="clear: both;" ></div> </div> <div class="another-box"></div> <body>Copy the code

3. Set height for floating parent element (poor extensibility)

To float a child element without height collapse, you can set the height of the parent element directly. However, this method is not extensible, it is not possible to add height to all the boxes in practical application, not only troublesome, and can not adapt to the rapid change of the page; Alternatively, the height of the parent container can be stretched by the content (such as an IMG image), which is often used in practice.

Clear float with ::after pseudo-element (recommended)

We can clear the float by setting the ::after pseudo-element. Add a ::after pseudo-element to the parent element of the height collapse, and set a certain style to this pseudo-element to clear the float. The principle is similar to the second method, but this method not only solves the problem of height collapse, but also does not cause page structure redundancy, so it is the most common method to clear float at present, and it is recommended to use it. The specific code is as follows:

.parent-box {      width: 200px;      background: gray;      border: 5px solid;    }    .parent-box::after {      content: "";      display: block;      clear: both;    }
Copy the code

But IE6 7 does not support false elements. In order to be compatible with most browsers, we can combine hasLayout with IE6 7 and below to solve the height collapse problem perfectly.

Five, BR label clearance float

The BR tag has an attribute clear. This property is useful for clearing floats. Set clear in the BR tag and assign all to clear floats. But this approach, like the second, also makes the page structure redundant. The specific code is as follows:

<body>
   <div class="parent-box">
   <div class="son-box"></div>
   <br clear="all" />  
   </div>
   <div class="another-box"></div>
<body>
Copy the code

Above several clear float on xiaobai introduction, solve the problem of height collapse method, if there is any wrong place, or there is a better way, please advise!!