css – 流体宽度表中的响应图像(最大宽度)

考虑以下代码:

HTML

<div>
    <img src="http://placehold.it/600x150" />
</div>

CSS:

div { max-width: 200px }
img { max-width: 100%  }​

无论原始大小如何,图像都不会超过200像素.到现在为止还挺好.

这是小提琴:http://jsfiddle.net/PeAAb/

但是,如果父元素的显示设置为table:

div { max-width: 200px; display: table }

图像神奇地扩展到原始宽度,用它扩展表格.

这是小提琴:http://jsfiddle.net/PeAAb/1/

实际表也是如此:http://jsfiddle.net/PeAAb/2/

问题:这是预期的行为吗?如果是这样,可以采取哪些措施来解决这个问题?

设置父级的宽度(甚至是基于百分比的宽度)而不是最大宽度正确地将图像压缩回其框中,但不是解决方案.我需要父母是流动的(我正在使用它作为网站的主要结构,所以我可以拥有the sidebar HTML appear after the main content in the source,but with the sidebar being fixed width).

此外,setting table-layout to fixed似乎在这里有no effect.

解决方法

这里的问题是表(或设置为表格的div)不是块元素,max-width仅适用于块元素.我唯一的建议是将table元素包装在一个带有display:block的div中;组.

如果你感兴趣的话,这就是小提琴:http://jsfiddle.net/PeAAb/4/

相关文章

css的bordercolor属性怎么使用
CSS中contain属性的作用和语法
深入学习响应式布局框架:适合初学者到专家的详尽指南
CSS3选择器优先级规则
margin-top用法
选择最适合您的响应式布局框架:综合评估不同工具