我想有纯html+css解决方案。如果没有其他解决方案,我可以想象用javascript来处理它。
备注:B中的图片应该进行修剪而不是调整大小。在真正的解决方案中,将有div与显示:表和所以,不是html表。
/*same*/
#container {
width: 600px;
border: 1px solid blue;
margin: 0 auto;
overflow: hidden;
}
img {
width: 120px;
height: 90px;
background-color: red;
}
/*different*/
table {
margin: 0 auto;
}
td {
padding: 5px;
}
<div id="container">
A (OK):
<table>
<tr>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<tr>
</table>
B (not OK - overflowing):
<table>
<tr>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<tr>
</table>
</div>
2)
/*same*/
#container {
width: 600px;
border: 1px solid blue;
margin: 0 auto;
overflow: hidden;
}
img {
width: 120px;
height: 90px;
background-color: red;
}
/*different*/
table {
margin: 0 auto;
width: 100% !important;
table-layout:fixed;
}
td {
padding: 5px;
overflow: hidden;
}
<div id="container">
A (not OK - using whole width, spaces too big):
<table>
<tr>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<tr>
</table>
B (OK):
<table>
<tr>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<td><img src="" /></td>
<tr>
</table>
</div>