一般的方法是使用float:
[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
另一种方法是将每个网格显示为inline-block(行内块元素),再设置其父容器的text-align:justify(两端对齐),这样的话每行的网格都会根据父容器宽度自适应个数和间距:
[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
可能还有一些问题,看这个文章: http://www.zhangxinxu.com/wordpress/2011/03/displayinline-blocktext-alignjustify%E4%B8%8B%E5%88%97%E8%A1%A8%E7%9A%84%E4%B8%A4%E7%AB%AF%E5%AF%B9%E9%BD%90%E5%B8%83%E5%B1%80/ http://targetkiller.net/inline-block/
大概就是说: 用span,别用div。 结束标签连着写,别折行。 最后一行加个透明的行。
供参考:
<div>销售排行</div><br/> <div style="width:100%;text-align:justify"> <c:forEach var="oneRow" items="${topSellList}" varStatus="sta"> <span style="width:180px;height:200px;display:inline-block;vertical-align:top;"> <a href="${ctx}/mobile/showProduct?id=${oneRow.id}"> <img src="/fileStore/productImage/${oneRow.productPic1}" width="100" height="100" style="margin: 5px" /><br/>${oneRow.productName} </a> <div style="color: #de4b03;"><i class="iconRMB">¥</i>${oneRow.sellPrice}</div></span> </c:forEach> <!-- 解决最后一行不撑满的问题 --> <span style="display:inline-block; width:100%; height:0; overflow:hidden;"></span> </div> <div style="clear:both"></div>
|