IE8 overflow:auto with max-height

后端 未结 8 2029
鱼传尺愫
鱼传尺愫 2020-12-04 11:42

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

相关标签:
8条回答
  • 2020-12-04 11:55
    {
    overflow:auto
    }
    

    Try div overflow:auto

    0 讨论(0)
  • 2020-12-04 11:57

    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.

    0 讨论(0)
  • 2020-12-04 11:58

    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>
    
    0 讨论(0)
  • 2020-12-04 12:00
    {max-height:200px, Overflow:auto}
    

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

    0 讨论(0)
  • 2020-12-04 12:00

    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.

    0 讨论(0)
  • 2020-12-04 12:06

    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>
    
    0 讨论(0)
提交回复
热议问题