当前位置: 首页 > 网络学院 > 网页制作基础教程 > WEB设计综合 > 像表格table一样轻松布局div层

WEB设计综合
连接基础
HTML基础
CSS 基础
添加背景音乐
HTML中的脚本标签
水平线样式
CSS基础以及CSS代码
自定义404错误页
链接至外部样式表
文本和颜色
表格详述
图像详述
优化CSS样式表代码
CSS元素div ul dl dt ol简释
CSS元素的class与ID命名常用关键字
DIV布局SEO的影响
CSS中的相对定位与绝对定位
CSS选择符
CSS特殊选择符伪类的应用技巧
常用的CSS知识

WEB设计综合 中的 像表格table一样轻松布局div层


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-03-01   浏览: 1235 ::
收藏到网摘: n/a

许多网页设计师都喜欢,将两个或者多个容器等高的并排放置,并在里面展示每个容器的内容,就象经典表格布局中的单元格控制几个栏目的位置,也喜欢容器的内容居中或顶部对齐显示。

但是你又不喜欢用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经过测试均可以完美显示.

评论 (0) All

登陆 | 还没注册?