It is easy to arrange DIVs horizontally with float. For example:
<div style="width: 500px;">
<div style="float:left; width: 200px; height: 100px; background-color:Yellow;"></div>
<div style="float:left; width: 150px; height: 60px; background-color:Blue;"></div>
<div style="float:left; width: 140px; height: 240px; background-color:Green;"></div>
<div style="float:left; width: 180px; height: 200px; background-color:Red;"></div>
<div style="float:left; width: 130px; height: 160px; background-color:Purple;"></div>
</div>
This will produce:
But how to arrange the DIVs both horizontally and vertically? In this case, how to shift the Red and Purple DIVs upper where there is empty space (under Yellow and Blue DIVs)?
NOTE: This is just an example, and I wish to find a method to make the arrangement for any set of DIVs (not only this typical example).
Assuming you are working with a dynamic set of arbitrarily sized objects, there is no pure CSS method to achieve this. You can get close by using a CSS3 multi-column layout if:
Here, objects are arranged in groups of 300px height.
<div id="blocks">
<div style="height: 100px; background-color: yellow;"></div>
<div style="height: 200px; background-color: blue;"></div>
<div style="height: 300px; background-color: green;"></div>
<div style="height: 200px; background-color: red;"></div>
<div style="height: 160px; background-color: purple;"></div>
</div>
#blocks {
-moz-column-count: 3;
-moz-column-gap: 0;
-webkit-column-count: 3;
-webkit-column-gap: 0;
column-count: 3;
column-gap: 0;
width: 450px;
}
#blocks div {
width: 150px;
}
http://jsfiddle.net/RTLun/
you could use position:absolute
css property along with top
,left
to achieve the same.
<div style="width: 500px;">
<div style="position:absolute; width: 200px; height: 100px; background-color:Yellow;"></div>
<div style="position:absolute; left:200px; width: 150px; height: 60px; background-color:Blue;"></div>
<div style="position:absolute;left:350px; width: 140px; height: 240px; background-color:Green;"></div>
<div style="position:absolute;top:100px; width: 180px; height: 200px; background-color:Red;"></div>
<div style="position:absolute; left:200px;top:60px;width: 130px; height: 160px; background-color:Purple;"></div>
</div>
Live demo
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With