Position属性四个值:static、fixed、absolute和relative的区别和用法

  在用CSS+DIV进行布局的时候,一直对position的四个属性值relative,absolute,static,fixed分的不是很清楚,以至常常会出现让人很郁闷的结果。今天研究了一下,总算有所了解。在此总结一下:浏览器

先看下各个属性值的定义:布局

一、static(静态定位):默认值。没有定位,元素出如今正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。spa

二、relative(相对定位):生成相对定位的元素,经过top,bottom,left,right的设置相对于其正常(原先自己)位置进行定位。可经过z-index进行层次分级。  对象

三、absolute(绝对定位):生成绝对定位的元素,相对于 static 定位之外第一个父元素进行定位。元素的位置经过 "left", "top", "right" 以及 "bottom" 属性进行规定。可经过z-index进行层次分级。blog

四、fixed(固定定位):生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置经过 "left", "top", "right" 以及 "bottom" 属性进行规定。可经过z-index进行层次分级。文档

static与fixed的定位方式较好理解,在此不作分析。下面对应用的较多的relative和absolute进行分析:页面布局

一、relativeit

    定位为relative的元素脱离正常的文本流中,但其在文本流中的位置依然存在io

    他是默认参照父级的原始点为原始点,无父级则以文本流的顺序在上一个元素的底部为原始点,配合TRBL进行定位,当父级内有padding等CSS属性时,当前级的原始点则参照父级内容区的原始点进行定位,有如下属性:float

  1)若是没有TRBL,以父级的左上角,在没有父级的时候,他是参照浏览器左上角(到这里和absolute第一条同样),若是在没有父级元素的状况下,存在文本,则以文本的底部为原始点进行定位并将文字断开(和absolut不一样)。

  2)若是设定TRBL,而且父级没有设定position属性,仍旧以父级的左上角为原点进行定位(和absolut不一样)。

  3)若是设定TRBL,而且父级设定position属性(不管是absolute仍是relative),则以父级的左上角为原点进行定位,位置 由TRBL决定(前半段和absolute同样)。若是父级有Padding属性,那么就之内容区域的左上角为原点,进行定位(后半段和absolut不 同)。

  以上三点能够总结出,不管父级存在不存在,不管有没有TRBL,均是以父级的左上角进行定位,可是父级的Padding属性会对其影响。
  综合上面对relative的叙述,咱们就能够将position属性为relative的DIV视成能够用TRBL进行定位的的普通DIV,或者说 只要将咱们平时布局页面的div的CSS属性中加上position:relative后,就不仅是用float布局页面了,还能够用TRBL进行布局页 面 了,或者说加上position:relative的DIV也能够像普通的DIV进行布局页面了,只不过还能够用TRBL进行布局页面。可是 position属性为absolute不能够用来布局页面,由于若是用来布局的话,全部的DIV都相对于浏览器的左上角定位了,因此只能用于将某个元素 定位于属性为absolute的元素的内部某个位置。

    Top的值表示对象相对原位置向下偏移的距离bottom的值表示对象相对原位置向上偏移的距离,二者同时存在时,只有Top起做用。

    left的值表示对象相对原位置向右偏移的距离right的值表示对象相对原位置向左偏移的距离,二者同时存在时,只有left起做用。

    如图1:

CSS+DIV定位分析(relative,absolute,static,fixed) - 心碎乌托邦 - love_heartbreaking

黄色背景的层定位为relative,红色边框区域为其在正常流中的位置。在经过top、left对其定位后,从灰色背景层的位置能够看出其正常位置依然存在。

 

二、absolute

    定位为absolute的层脱离正常文本流,但与relative的区别是其在正常流中的位置再也不存在

这个属性老是有人给出误导。说当position属性设为absolute后,老是按照浏览器窗口来进行定位的,这实际上是错误的。实际上,这是fixed属性的特色。

  1)若是没有TRBL(top、right、bottom、left),以父级的左上角,在没有父级的时候,他是参照浏览器左上角,若是在没有父级元素的状况下,存在文本,则以它前面的最后一个文字的右上角为原点进行定位可是不断开文字,覆盖于上方。
  2)若是设定TRBL,而且父级没有设定position属性,那么当前的absolute则以浏览器左上角为原始点进行定位,位置将由TRBL决定。
  3)若是设定TRBL,而且父级设定position属性(不管是absolute仍是relative),则以父级的左上角为原点进行定位,位置由 TRBL决定。即便父级有Padding属性,对其也不起做用,说简单点就是:它只坚持一点,就以父级左上角为原点进行定位,父级的padding对其根 本没有影响。

以上三点能够总结出,若想把一个定位属性为absolute的元素定位于其父级元素内,只有知足两个条件:

  第一:设定TRBL

  第二:父级设定Position属性

  上面的这个总结很是重要,能够保证你在用absolue布局页面的时候,不会错位,而且随着浏览器的大小或者显示器分辨率的大小,而不发生改变。

  只要有一点不知足,元素就会以浏览器左上角为原点,这就是初学者容易犯错的一点,已经定位好的板块,当浏览器的大小改变,父级元素会随之改变,可是设 定Position属性为absolute的板块和父级元素的位置发生改变,错位了,这就是由于此时元素以浏览器的右上角为原点的缘由。
  初学者很容易犯错的是,不清楚Position属性为absolute的板块,若想定位到父级板块中,而且当浏览器的大小改变或显示器的分辨率改变,布局不发生改变,是须要知足两个条件的,只要有一点不知足,元素就会以浏览器左上角为原点,从而致使页面布局错位。

    Top的值表示对象上边框与浏览器窗口顶部的距离,bottom的值表示对象下边框与浏览器窗口底部的距离,二者同时存在时,只有Top起做用;若是二者都未指定,则其顶端将与原文档流位置一致,即垂直保持位置不变

    left的值表示对象左边框与浏览器窗口左边的距离,right的值表示对象右边框与浏览器窗口右边的距离,二者同时存在时,只有left起做用;若是二者都未指定,则其左边将与原文档流位置一致,即水平保持位置不变。 

    在Position属性值为absolute的同时,若是有一级父对象(不管是父对象仍是祖父对象,或者再高的辈分,同样)的Position属性值为Relative时,则上述的相对浏览器窗口定位将会变成相对父对象定位,这对精肯定位是颇有帮助的。

三、relative与absolute的主要区别

首先,是上面已经提到过的在正常流中的位置存在与否。

其次,relative定位的层老是相对于其最近的父元素,不管其父元素是何种定位方式。如图3:

图中,红色背景层为relative定位,其直接父元素绿色背景层为默认的static定位。红色背景层的位置为相对绿色背景层top、left个20元素。而若是红色背景层定位为absolute,则情形以下:

CSS+DIV定位分析(relative,absolute,static,fixed) - 心碎乌托邦 - love_heartbreaking

 

可 以看到,红色背景层依然定义top:20px;left:20px;但其相对的元素变为定位方式为absolute或relative的黄色背景层。因 此,对于absolute定位的层老是相对于其最近的定义为absolute或relative的父层,而这个父层并不必定是其直接父层。若是其父层中都未定义absolute或relative,则其将相对body进行定位,如图:

 

除top、left、right、bottom定位外,margin属性值的定义也符合上述规则。

总结:

  属性为relative的元素能够用来布局页面,属性为absolute的元素用来定位某元素在父级中的位置,既然属性为absolute的元素用来定位某元素在父级中位置,就少不了TRBL,这时候根据一开始讲的absolute的第三条,若是父级元素没有position属性那么 absolute元素就会脱离父级元素,可是若是是布局页面,父级元素position的属性又不能为absolute,否则就会以浏览器左上角为原点 了,因此父级元素的position属性只能为relative!

  若是用position来布局页面,父级元素的position属性必须为relative,而定位于父级内部某个位置的元素,最好用 absolute,由于它不受父级元素的padding的属性影响,固然你也能够用position,不过到时候计算的时候不要忘记padding的值

Note : 绝对(absolute)定位对象在可视区域以外会致使滚动条出现。而放置相对(relative)定位对象在可视区域以外,滚动条不会出现。

什么是文档流?

      将窗体自上而下分红一行行, 并在每行中按从左至右的顺序排放元素,即为文档流。

      只有三种状况会使得元素脱离文档流,分别是:浮动绝对定位和相对定位。

z-index属性

       z-index,又称为对象的层叠顺序,它用一个整数来定义堆叠的层次,整数值越大,则被层叠在越上面,固然这是指同级元素间的堆叠,若是两个对象的此属 性具备一样的值,那么将依据它们在HTML文档中流的顺序层叠,写在后面的将会覆盖前面的。须要注意的是,父子关系是没法用z-index来设定上下关系 的,必定是子级在上父级在下。

Note:使用static 定位或无position定位的元素z-index属性是无效的。