css相对定位和绝对定位有哪些区别

2023-05-26,,

小编给大家分享一下css相对定位绝对定位有哪些区别,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

一、首先我们来看一看css相对定位

position: relative(相对定位):相对定位是相对于元素在文档中的初始位置。

首先它出现在它所在的位置上(即不设置position时的位置,然后通过设置垂直或水平位置,让这个元素“相对于”它的原始起点进行移动。

需要注意的是:在使用相对定位时,无论是否进行移动,元素仍然占据原来的空间。因此,移动元素会导致它覆盖其它框。

#box_relative {
  position: relative;
  left: 30px;
  top: 20px;
}

二、再来看一下css绝对定位:

position: absolute(绝对定位):绝对定位是相对于元素最近的已定位的祖先元素(即是设置了绝对定位或者相对定位的祖先元素)。如果元素没有已定位的祖先元素,那么它的位置则是相对于最初的包含块(body)。

#box_relative {
  position: absolute;
  left: 30px;
  top: 20px;
}

说明:绝对定位本身与文档流无关,因此不占空间,普通文档流中的元素的布局就当绝对定位的元素不存时一样,所以 它们可以覆盖页面上其他的元素,且可以通过z-index属性来控制这些层的对方顺序。

三、最后我们总结一下css相对定位和绝对定位的区别

position:absolute(绝对定位)float会隐式地改变display的类型(display:none除外)。

即是当元素设置position:absolute、float:left、float:right中任意一个时,都会让元素以display:inline-block的方式显示(特点是:可以设置长宽,默认宽度不占满父元素)。这时,即使故意设置display:inline;
display:block都是无效的。
但是float在IE6下的双边距bug就是用display:inline; 来解决的。

position:relative(相对定位)不会隐式改变display的类型。

在默认情况下,相对定位是相对于元素本身所在的位置去定位;绝对定位是相对于左上角坐标原点去定位。

看完了这篇文章,相信你对css相对定位和绝对定位有哪些区别有了一定的了解,想了解更多相关知识,欢迎关注本站行业资讯频道,感谢各位的阅读!

《css相对定位和绝对定位有哪些区别.doc》

下载本文的Word格式文档,以方便收藏与打印。