IE8 overflow:auto with max-height

Internet Explorer-8OverflowCss

Internet Explorer-8 Problem Overview


I have an element which may contain very big amounts of data, but I don't want it to ruin the page layout, so I set max-height: 100px and overflow:auto, hoping for scrollbars to appear when the content does not fit.

It all works fine in Firefox and IE7, but IE8 behaves as if overflow:hidden was present instead of overflow:auto.

I tried overflow:scroll, still does not help, IE8 simply truncates the content without showing scrollbars. Changing max-height declaration to height makes overflow work OK, it's the combination of max-height and overflow:auto that breaks things.

This is also logged as an official bug in the final, release version of IE8

Is there a workaround? For now I resorted to using height instead of max-height, but it leaves plenty of empty space in case there isn't much data.

Internet Explorer-8 Solutions


Solution 1 - Internet Explorer-8

This is a really nasty bug as it affects us heavily on Stack Overflow with <pre> code blocks, which have max-height:600 and width:auto.

It is logged as a bug in the final version of IE8 with no fix.

http://connect.microsoft.com/IE/feedback/ViewFeedback.aspx?FeedbackID=408759

There is a really, really hacky CSS workaround:

http://my.opera.com/dbloom/blog/2009/03/11/css-hack-for-ie8-standards-mode

/*
SUPER nasty IE8 hack to deal with this bug
*/
pre 
{
	max-height: none\9 
}

and of course conditional CSS as others have mentioned, but I dislike that because it means you're serving up extra HTML cruft in every page request.

Solution 2 - Internet Explorer-8

{
overflow:auto
}

Try div overflow:auto

Solution 3 - Internet Explorer-8

I saw this logged as a fixed bug in RC1. But I've found a variation that seems to cause a hard assert render failure. Involves these two styles in a nested table.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <title>Test</title>
    <style type="text/css">
    .calendarBody
	{
	    overflow: scroll;
	    max-height: 500px;
	}
	</style>
</head>
<body>
    <table>
    <tbody>
        <tr>
	    <td>
	        This is a cell in the outer table.
		<div class="calendarBody">
		    <table>
		        <tbody>
			    <tr>
			        <td>
				    This is a cell in the inner table.
				</td>
		            </tr>
			</tbody>
	            </table>
		</div>
	    </td>
	</tr>
    </tbody>
</table>
</body>
</html>

Solution 4 - Internet Explorer-8

{max-height:200px, Overflow:auto}

Thanks to Srinivas Tamada, The above code did work for me.

Solution 5 - Internet Explorer-8

To reproduce:

(This crashes the whole page.)

<HTML>
<HEAD>
    <META content="IE=8" http-equiv="X-UA-Compatible"/>
</HEAD>

<BODY>
    look:
    
    <TABLE width="100%">
        <TR>
            <TD>
                <TABLE width="100%">
                    <TR>
                        <TD>
                            <DIV style="overflow-y: scroll; max-height: 100px;">
                                X
                            </DIV>
                        </TD>
                    </TR>
                </TABLE>
            </TD>
        </TR>
    </TABLE>
</BODY>
</HTML>

(Whereas this works fine...)

<HTML>
<HEAD>
    <META content="IE=8" http-equiv="X-UA-Compatible"/>
</HEAD>

<BODY>
    look:
    
    <TABLE width="100%">
        <TR>
            <TD>
                <TABLE width="100%">
                    <TR>
                        <TD>
                            <DIV style="overflow-y: scroll; max-height: 100px;">
                                The quick brown fox
                            </DIV>
                        </TD>
                    </TR>
                </TABLE>
            </TD>
        </TR>
    </TABLE>
</BODY>
</HTML>

(And, madly, so does this. [No content in the div at all.])

<HTML>
<HEAD>
    <META content="IE=8" http-equiv="X-UA-Compatible"/>
</HEAD>

<BODY>
    look:
    
    <TABLE width="100%">
        <TR>
            <TD>
                <TABLE width="100%">
                    <TR>
                        <TD>
                            <DIV style="overflow-y: scroll; max-height: 100px;">
                            </DIV>
                        </TD>
                    </TR>
                </TABLE>
            </TD>
        </TR>
    </TABLE>
</BODY>
</HTML>

Solution 6 - Internet Explorer-8

Similar situation, a pre element with maxHeight set by js to fit in allotted space, width 100%, overflow auto. If the content is shorter than maxHeight and also fits horizontally, we're good. If you resize the window so the content no longer fits horizontally, a horizontal scrollbar appears, but the height of element immediately jumps to the full maxHeight, regardless of the height of the content.

Tried various forms of the css hack mentioned by Jeff, but didn't find anything like it that wasn't a js bad-parameter error.

Best I could find was to pick your poison for ie8: Either drop the maxHeight limit, so the element can be any height (best for my case), or set height rather than maxHeight, so it's always that tall even if the content itself is much shorter. Very not ideal. Wacked behavior is gone in ie9.

Solution 7 - Internet Explorer-8

Set max-height only and don't set the overflow. This way it will show scroll bar if content is more than max-height and shrinks if content is less than the max-height.

Solution 8 - Internet Explorer-8

I found this : https://perishablepress.com/maximum-and-minimum-height-and-width-in-internet-explorer/

> This method has been verified in IE6 and should also work in IE5. Simply change the values to suit your needs (code commented with explanatory notes). In this example, we are setting the max-height at 333px 1 for IE and all standards-compliant browsers:

>* html div#division { height: expression( this.scrollHeight > 332 ? "333px" : "auto" ); /* sets max-height for IE */ }

and this works for me perfectly so I decided to share this.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionRytisView Question on Stackoverflow
Solution 1 - Internet Explorer-8Jeff AtwoodView Answer on Stackoverflow
Solution 2 - Internet Explorer-8EgglabsView Answer on Stackoverflow
Solution 3 - Internet Explorer-8James KochView Answer on Stackoverflow
Solution 4 - Internet Explorer-8Ashish JosephView Answer on Stackoverflow
Solution 5 - Internet Explorer-8ANevesView Answer on Stackoverflow
Solution 6 - Internet Explorer-8enigmentView Answer on Stackoverflow
Solution 7 - Internet Explorer-8Abdul RaufView Answer on Stackoverflow
Solution 8 - Internet Explorer-8Vadim SvvView Answer on Stackoverflow