您当前的位置: 首页 > 前端教程 > HTML教程 > 像表格table一样轻松布局div层

像表格table一样轻松布局div层

作者:guanchaofeng 来源:不详 发布时间: 2007-11-15 12:46 点击:
下面是我翻译的内容,是根据我对文章的理解意译的,你就别挑哪里翻译的不对了,我的目的只是传达这个CSS技巧。 许多网页设计师都喜欢,将两个或者多个容器等高的并排放置,并在里面展示每个容器的内容,就象经典表格布局中的单元格控制几个栏目的位置,也喜欢

像表格table一样轻松布局div层

下面是我翻译的内容,是根据我对文章的理解意译的,你就别挑哪里翻译的不对了,我的目的只是传达这个CSS技巧。 
许多网页设计师都喜欢,将两个或者多个容器等高的并排放置,并在里面展示每个容器的内容,就象经典表格布局中的单元格控制几个栏目的位置,也喜欢容器的内容居中或顶部对齐显示。 
但是你又不喜欢用table来实现他,那怎么办呢?实现的方法很多,有根据视觉错觉实现的,有用JS控制使高度相等的,还有采用容器溢出部分隐藏和列的负底边界和正的内补丁相结合的方法来解决列高度相同的问题。 
其实有个简单的方法,使用display:table, display:table-row and display:table-cell 就可以实现,而且高度小的容器会自适应那些高度相对较高的,但是IE不支持这个属性,我们先不用去责备IE,相信以后会有所改善的。这里我制作了一个模型。 
先看看xhtml的结构: 
<div class="equal"> 
<div class="row"> 
<div class="one"></div> 
<div class="two"></div> 
<div class="three"></div> 
</div> 
</div> 
很简单不用解释就能看懂,但是这里给出一个table的结构,是不是很相似 
<table> 
<tr> 
<td></td> 
<td></td> 
<td></td> 
</tr> 
</table> 
下来是css: 
.equal { 
display:table; 
border-collapse:separate; 

.row { 
display:table-row; 

.row div { 
display:table-cell; 

.row .one { 
width:200px; 

.row .two { 
width:200px; 

.row .three { 

解释: 
1.dispaly:table;让层.equal作为块级元素的表格table显示,也就是将他作为一个表格 
2.border-collapse:separate;边框独立,就像表格没有合并单元格以前 
3.display:table-row;将.row作为表格行tr显示 
4.display:table-cell;将.row的下级div作为表格单元格td显示 
5.然后定义宽度 
这里还使用了 border-spacing:10px;来区别几个盒子,正如上面所陈述的,IE下不能正常显示,但是在:Mozilla 1.6, Opera 7.50, Safari 1.2.2, Firefox 0.8, OmniWeb 5b, Camino 0.8b, and Netscape 7.1经过测试均可以完美显示. 
分享到:
本文"像表格table一样轻松布局div层"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4