为什么Firefox和Opera忽略display:table-cell里面的max-width?

bra*_*rad 67 html css css-tables

以下代码在Chrome或IE中正确显示(图像宽度为200px).在Firefox和Opera中,max-width样式完全被忽略.为什么会发生这种情况并且有好的解决方法?另外,哪种方式符合大多数标准?

注意

针对这种特殊情况的一种可能的解决方法是设置max-width200px.然而,这是一个相当人为的例子.我正在寻找一个可变宽度容器的策略.

<!doctype html>
<html>
<head>
    <style>
        div { display: table-cell; padding: 15px; width: 200px; }
        div img { max-width: 100%; }
    </style>
</head>
<body>
    <div>
        <img src="http://farm4.static.flickr.com/3352/4644534211_b9c887b979.jpg" />
        <p>
            Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec facilisis
            ante, facilisis posuere ligula feugiat ut. Fusce hendrerit vehicula congue.
            at ligula dolor. Lorem ipsum dolor sit amet, consectetur adipiscing elit.
            leo metus, aliquam eget convallis eget, molestie at massa.
        </p>
    </div>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

[更新]

如下面的mVChr所述,w3.org规范声明max-width不适用于inline元素.我尝试过使用div img { max-width: 100%; display: block; },但似乎没有解决问题.

[更新]

我仍然没有解决这个问题的方法.但是,我使用以下javascript hack来解决我的问题.从本质上讲,它再现了以上和检查的情况,如果浏览器支持max-width范围内display: table-cell.(使用数据uri可以防止额外的http请求.下面的一个是3x3 bmp.)

jQuery( function ( $ ) {

    var img = $( "<img style='max-width:100%' src='" +
    "" +
    "AMAAAABAAEAAAAAAAwAAADEDgAAxA4AAAAAAAAAAAAAAAAAAP//" +
    "/wAAAAAAwAAAAKAAAAA%3D" +
    "'>" )
    .appendTo(
        $( "<div style='display:table-cell;width:1px;'></div>" )
        .appendTo( "body" )
    );
    $.support.tableCellMaxWidth = img.width() == 1;
    img.parent().remove();

});
Run Code Online (Sandbox Code Playgroud)

小智 120

你需要做的是把你的包装div(与display: table-cell那个)放在另一个包含display: table 和的 div中table-layout: fixed.这使Firefox和Opera都遵守max-width规则.

在jsFiddle上查看此示例.


mVC*_*Chr 31

w3.org规范指出,最大宽度并不适用于内联元素,所以你会得到跨浏览器的行为不一致.我不知道你的意图的结果,但你可以做到,如果你设置div img { display:block },然后对齐imgp标签用浮漂,而不是标准的内联.

  • 以下是规范的确切部分:http://www.w3.org/TR/CSS2/visudet.html#min-max-widths (2认同)