什么是DIV的相对布局和绝对布局

来源:百度知道 编辑:UC知道 时间:2024/05/26 16:14:31
好多人都在讲DIV的相对布局和绝对布局,我是个新手,我布局的方法就是计算不同DIV之间的距离来定位的,但好像这样在不同尺寸的显示器会变形,请高手指点一下!
我主要就是想知道什么是相对布局,相对布局的“相对”是相对谁的,还有什么是绝对布局!

position:relative|相对定位

使用position:relative,就需要top,bottom,left,right4个属性来配合,确定元素的位置。
如果要让div-1层向下移动20px,左移40px:

example代码:
#div-1 {
position:relative;
top:20px;
left:40px;
}
如果用到相对定位,紧随他的层divafter是不会出现在div-1的下方,而是和div-1在同一个高度出现。

可见, position:relative;并不是很好用。

position:absolute|绝对定位
使用position:absolute;,能够很准确的将元素移动到你想要的位置,
让我将 div-1a 移动到页面的右上角:

example代码:
#div-1a {
position:absolute;
top:0;
right:0;
width:200px;
}
使用绝对定位的div-1a层前面的或者后面的层会认为这个层并不存在,丝毫不影响到他们。所以position:absolute;用于将一个元素放到固定的位置很好用,但是如果需要div-1a层相对于附近的层来确定位置就不要实现了。
*这里有个Win IE的bug需要提到,就是如果为绝对定位的元素定义一个相对的宽度,那么在IE下它的宽度取决于父元素的宽度而不是整个页面的宽度。

position:relative + position:absolute|绝对定位+相对定位

如果给父元素(div-1)定义为position:relative;子元素(div-1a)定义为position:absolute,那么子元素(div-1a)的位置将相对于父元素(div-1),而不是整个页面。
让div-1a定位于div-1的右上角:

代码实例:
<div id="d