小谈CSS定位

时间:2022-02-15 15:09:07

定义和用法

position 属性规定元素的定位类型。

说明

这个属性定义建立元素布局所用的定位机制。任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而不论该元素本身是什么类型。相对定位元素会相对于它在正常流中的默认位置偏移。

描述
absolute

生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。

元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

fixed

生成绝对定位的元素,相对于浏览器窗口进行定位。

元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。

relative

生成相对定位的元素,相对于其正常位置进行定位。

因此,"left:20" 会向元素的 LEFT 位置添加 20 像素。

static 默认值。没有定位,元素出现在正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。
inherit 规定应该从父元素继承 position 属性的值。

以上内容摘自w3c    http://www.w3school.com.cn/css/pr_class_position.asp

自己的理解:

一个元素在默认情况下是没有定位的,即所说的static属性,

div1
div2

正常情况下div1 和div2都是默认定位,所以他们在属于文档流,也有说是标准流的,此时div1和div2是占空间的,div2之所以在div1的下面,就是因为div1 属于标准流,有自己的空间,其他元素无法占据其位置,只能挨着排放。

此时改变div1的position属性为absolute,效果如下

div1
div2

从上边的例子可以清楚的看到div2 占据了div1的位置,并没有在div1的下面排放,这是为什么呢?

当position:absolute 时,此时div1 已经不再属于文档流(脱离了文档流),也就是说div1 不占据任何空间,好比div1 浮起来了,导致div2占去它的空间。

此时改变div1的position属性为relative,效果如下

div1
div1 position: relative
div2

从上边的例子可以清楚的看到div2并没有 占据了div1的位置,而是在div1的下面排放,这是为什么呢?

当position:relative 时,表示div1 此时是相对定位,相对谁呢?相对自己,就是上图的红色边框div相对自己以前的位置(红色虚线框)进行定位,此时div1属于文档流,是占据空间的,还是虚线框所占的空间。所有div2无法上移。

此时改变div1的position属性为absolute,效果如下

div1 position: fixed
div2

当positon:fixed 时 div1此时相对浏览器惊醒定位,同样也脱硫了文档流,不占据任何空间,div2 上移 占据div1 的位置。表现为 无论怎么拖动滚动条,div1位置相对浏览器始终不变。

好了,到此打住,放张美女提提神小谈CSS定位