前面我在解读CSS中也说过了关于相对定位和绝对定位的问题,无奈还是有些童鞋表示迷茫,于是另开一篇博客,来详细解读相对定位和绝对定位,希望能够以我的点点星光,让后来者少走弯路。
所谓相对定位,就是设置为相对定位的元素会偏移某个距离,元素仍然保持原来的样式,它会保留该HTML元素的空间,比如我们看如下代码:
.demo{ position: relative; width:50px; height: 50px; left:50px; }它会出现在相对原来的地方向右50px的地方,而它原来所在的地方为空。
下面说一下绝对定位,所谓绝对定位,即不占用空间,如果原来这个地方有HTML元素,那么就会重叠,这里需要特别之处的,也是我发这篇博文的目的,就是想告诉大家,绝对定位如果被父元素包含,如果父元素没有定位属性,它会根据body进行定位,因此,如果它有父元素,必须在父元素中指定定位属性,如下代码:
<html> <head> <title>辛星解读绝对定位和相对定位</title> <style type="text/css"> .father{ position: relative; width:300px; height: 300px; margin: 0 auto; border: 1px solid orange; } .sun{ position:absolute; background:purple; width:50px; height: 50px; left: 50px; } </style> </head> <div class = "father"> <div class = "sun"></div> </div> </html>
可能有童鞋会问,如果我们不指定父元素的定位又会如何呢?请看下面代码,我把css代码中的哪一行给注释掉之后,源代码如下:
<html> <head> <title>辛星解读绝对定位和相对定位</title> <style type="text/css"> .father{ //position: relative; width:300px; height: 300px; margin: 0 auto; border: 1px solid orange; } .sun{ position:absolute; background:purple; width:50px; height: 50px; left: 50px; } </style> </head> <div class = "father"> <div class = "sun"></div> </div> </html>
以上就是我介绍的关于绝对定位和相对定位的问题,如果您有什么问题或者不解,可以在下面留言,谢谢。
原文:http://blog.csdn.net/xinguimeng/article/details/38067951