考虑以下代码:
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).
解决方法
这里的问题是表(或设置为表格的div)不是块元素,max-width仅适用于块元素.我唯一的建议是将table元素包装在一个带有display:block的div中;组.
如果你感兴趣的话,这就是小提琴:http://jsfiddle.net/PeAAb/4/
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。