考虑以下代码:
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/