Why do we need to use the CSS property 
clear with a value of both?
Example:
.clear { 
    clear:both; 
}
 
 won't be explaining how the floats work here (in detail), as this question generally focuses on Why use clear: both; OR what does clear: both; exactly do...
I'll keep this answer simple, and to the point, and will explain to you graphically why clear: both; is required or what it does...
Generally designers float the elements, left or to the right, which creates an empty space on the other side which allows other elements to take up the remaining space.
Why do they float elements?
Elements are floated when the designer needs 2 block level elements side by side. For example say we want to design a basic website which has a layout like below...
 Live Example of the demo image.
Code For Demo
Live Example of the demo image.
Code For Demo
HTML:
<header>
    Header
</header>
<aside>
    Aside (Floated Left)
</aside>
<section>
    Content (Floated Left, Can Be Floated To Right As Well)
</section>
<!-- Clearing Floating Elements-->
<div class="clear"></div>
<footer>
    Footer
</footer>
CSS:
* { /* Not related to floats / clear both, used it for demo purpose only */
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
}
header, footer {
    border: 5px solid #000;
    height: 100px;
}
aside {
    float: left;
    width: 30%;
    border: 5px solid #000;
    height: 300px;
}
section {
    float: left;
    width: 70%;
    border: 5px solid #000;
    height: 300px;
}
.clear {
    clear: both;
}
Note: You might have to add header, footer, aside, section (and other HTML5 elements) as display: block; in your stylesheet for explicitly mentioning that the elements are block level elements.
Explanation:
I have a basic layout, 1 header, 1 side bar, 1 content area and 1 footer.
No floats for header, next comes the aside tag which I'll be using for my website sidebar, so I'll be floating the element to left.
Note: By default, block level element takes up document 100% width, but when floated left or right, it will resize according to the content it holds.
So as you note, the left floated div leaves the space to its right unused, which will allow the div after it to shift in the remaining space.
- div's will render one after the other if they are NOT floated
- divwill shift beside each other if floated left or right
Ok, so this is how block level elements behave when floated left or right, so now why isclear: both;required and why?
So if you note in the layout demo - in case you forgot, here it is..
I am using a class called .clear and it holds a property called clear with a value of both. So lets see why it needs both.
I've floated aside and section elements to the left, so assume a scenario, where we have a pool, whereheader is solid land, aside and section are floating in the pool and footer is solid land again, something like this..
 So the blue water has no idea what the area of the floated elements are, they can be bigger than the pool or smaller, so here comes a common issue which troubles 90% of CSS beginners: why the background of a container element is not stretched when it holds floated elements. It's because the container element is aPOOL here and the POOL has no idea how many objects are floating, or what the length or breadth of the floated elements are, so it simply won't stretch.
So the blue water has no idea what the area of the floated elements are, they can be bigger than the pool or smaller, so here comes a common issue which troubles 90% of CSS beginners: why the background of a container element is not stretched when it holds floated elements. It's because the container element is aPOOL here and the POOL has no idea how many objects are floating, or what the length or breadth of the floated elements are, so it simply won't stretch.
- Normal Flow Of The Document
- Sections Floated To Left
- Cleared Floated Elements To Stretch Background Color Of The Container
I've provided 3 examples above, 1st is the normal document flow wherered background will just render as expected since the container doesn't hold any floated objects.
In the second example, when the object is floated to left, the container element (POOL) won't know the dimensions of the floated elements and hence it won't stretch to the floated elements height.
 After using
After using clear: both;, the container element will be stretched to its floated element dimensions.
 Another reason the
Another reason the clear: both; is used is to prevent the element to shift up in the remaining space.
Say you want 2 elements side by side and another element below them... So you will float 2 elements to left and you want the other below them.
- divFloated left resulting in- sectionmoving into remaining space
- Floated divcleared so that thesectiontag will render below the floateddivs
1st Example
 
2nd Example
 Last but not the least, the
Last but not the least, the footer tag will be rendered after floated elements as I've used the clear class before declaring my footer tags, which ensures that all the floated elements (left/right) are cleared up to that point.
ref:
http://stackoverflow.com/questions/12871710/why-clear-both-css
 
