I have an absolutely positioned div
containing several children, one of which is a relatively positioned div
. When I use a percentage-based width on the child div
, it collapses to '0' width on Internet Explorer 7, but not on Firefox or Safari.
If I use pixel width, it works. If the parent is relatively positioned, the percentage width on the child works.
- Is there something I'm missing here?
- Is there an easy fix for this besides the pixel-based width on the child?
- Is there an area of the CSS specification that covers this?
Here is some sample code. I think this is what you are looking for. The following displays exactly the same in Firefox 3 (mac) and IE7.
IE prior to 8 has a temporal aspect to its box model that most notably creates a problem with percentage based widths. In your case here an absolutely positioned
div
by default has no width. Its width will be worked out based on the pixel width of its content and will be calculated after the contents are rendered. So at the point IE encounters and renders your relatively positioneddiv
its parent has a width of 0 hence why it itself collapses to 0.If you would like a more in depth discussion of this along with lots of working examples, have a gander here.
I think this has something to do with the way the
hasLayout
property is implemented in the older browser.Have you tried your code in IE8 to see if works in there, too? IE8 has a Debugger (F12) and can also run in IE7 mode.
Because it's Internet Exploder
That is, to raise your co-worker's / clients' awareness that IE sucks.
Use
em
units as they are more useful when creating liquid layouts as you can use them for padding and margins as well as font sizes. So your white space grows and shrinks proportionally to your text if it is resized (which is really what you need). I don't think percentages give a finer control than ems; there's nothing to stop you specifying in hundredths of ems (0.01 em) and the browser will interpret as it sees fit.None, as far as I remember
em
's and %'s were intended for font sizes alone back at CSS 1.0.The parent
div
needs to have a definedwidth
, either in pixels or as a percentage. In Internet Explorer 7, the parentdiv
needs a definedwidth
for child percentagediv
s to work correctly.The
div
needs to have a defined width: