<html> <body style="background-color:#F8E0EC;"> <div style="background-color:#fff;padding:20px;border:10px solid blue;"> <div style="float:left;width:330px;border: 1px dotted red;"> <p> <strong>When:</strong> 12/5/2009 <strong>@</strong> 3:30 PM </p> <p> <strong>Where:</strong> 5 main street USA </p> <p> <strong>Description:</strong> test </p> <p> <strong>Contact:</strong> 425-555-1212 </p> </div> </div> </body> </html>The picture will look like this:
As you can see, most inner DIV text are sitting outside the blue box (outer DIV). If you take out the float attribute, everything will work fine. The reason of using float attribute is that you may want to have another DIV sit side-by-side together. In this situation, you need to put
<div style="clear:both"></div>at the end of the inner DIV, just before closing the outer DIV. In my example, I will continue to use only one inner DIV. You can test it yourself with two.
<html>
<body style="background-color:#F8E0EC;">
<div style="background-color:#fff;padding:20px;border:10px solid blue;">
<div style="float:left;width:330px;border: 1px dotted red;">
<p>
<strong>When:</strong>
12/5/2009
<strong>@</strong>
3:30 PM
</p>
<p>
<strong>Where:</strong>
5 main street
USA
</p>
<p>
<strong>Description:</strong>
test
</p>
<p>
<strong>Contact:</strong>
425-555-1212
</p>
</div>
<div style="clear:both"></div>
</div>
</body>
</html>
Now the problem is fixed.
Hi - I had the same problem. The answer was to give the parent div a height that covered the child divs.
ReplyDeleteJoel
Fix height won't work for dynamic content with different height.
ReplyDelete