position和float

position

position有四个值:static(默认),relative,absolute,fixed
postion 可以继承

普通文档流就是根据元素是行内元素 还是块级元素依次排列显示。

position不同的取值主要体现在元素是否脱离文档流是否改变行内元素的display属性值两个方面

下面是一个普通文档流:各元素按照顺序依次排列,每个元素都有一个“默认位置”

A
B
C
.a,.b,.c{ width:150px; height: 100px; } .a{ background-color: red; } .b{ background-color: green; } .c{ background-color: yellow; }
position和float_第1张图片
原始图

position:static
是默认的方式,所有元素在默认情况下都是static

position:relative
相对定位,相对于原来该元素在普通流中的位置重新定位,依旧在普通流中占据位置,没有脱离普通流,只是视觉上发生变化

.b{
    background-color: green;
    position: relative;
    top: 50px;
    left: 100px;
}

position和float_第2张图片
相对定位

相对定位不会使行内元素的display发生变化

DDDDD
.d{
    background-color: gold;
    position: relative;
    top: 50px;
    left: 100px;    
    width: 300px;
}
position和float_第3张图片
相对定位,行内元素

从上图中可见,.d没有设置上宽 ,所以相对定位并没有改变行内元素的display属性值

position:absolute
绝对定位:如果他的父元素都没有设置postion:relative|absolute,就根据根定位;否则根据设置了relative|absolute的父元素定位;绝对定位元素脱离文档流,并使块级元素的宽变为自适应(auto),元素的位置与文档流无关,也不占据文档空间。位置是相对于它最近的非static祖先元素的位置决定的。

BODY
WRAPPER
BBBB
.body{ height: 300px; background-color: blue; } .wrapper{ background-color: red; height: 200px; } .a,.b,.c{ height: 100px; } .b{ background-color: green; /* position: absolute; top: 200px; left: 200px;*/ }
position和float_第4张图片
原始图

放开.b的注释后,因为.b绝对定位,其余元素无定位,则.b相对于整个页面的根标签定位,BBBB宽度自适应

position和float_第5张图片

我们可以看到这里BBBB距离BODY最底边有一定的距离,是因为他相对于根定位,而自身有一定的margin和padding

给.wrapper添加postion:relative后,就相对.wrapper定位了,BBBB本身宽度自适应

position和float_第6张图片

给.wrapper添加postion:absolute后,相对.wrapper定位,且WRAPPER和BBBB本身宽度自适应

position和float_第7张图片

给.body添加postion:relative后,相对.body定位,且BBBB本身宽度自适应

position和float_第8张图片

给.body添加postion:absolute后,相对.body定位,且BBBB,WRAPPER,BODY宽度自适应

position和float_第9张图片

body wrapper 均为relative,则相对于最近的元素定位

position和float_第10张图片

BODY WRAPPER均为absolute,则都宽度自适应,相对于最近的元素定位

position和float_第11张图片

BODY是relative , WRAPPER是absolute,相对于最近的元素定位

position和float_第12张图片

BODY是absolute ,WRAPPER是relative,相对于最近的定位元素定位

position和float_第13张图片

结论

  1. 块状元素在position(relative/static)的情况下width为100%,但是设置了position: absolute之后,width变成auto(会受到父元素的宽度影响)
  2. 元素设置了position: absolute之后,如果没有设置top、bottom、left、right属性的话,浏览器会默认设置成auto,而auto的值则是该元素的“默认位置”,也就是只设置absolute,还是在默认位置
  3. 如果定位元素的父元素都没有设置绝对或者相对定位,那么该元素就根据根元素定位
  4. 如果定位元素的父元素有绝对或者相对定位,那么就相对最近的定位父元素定位
  5. position:absolute的行内元素会改变display,变为块级元素
  6. 覆盖其他非定位元素
  7. 脱离文档流

验证绝对定位会脱离文档流
此时BBBB元素未定位,正常的文档流中

BODY
WRAPPER
BBBB
AAAA
.a{ width: 100px; height: 100px; background-color: #ccc; }
position和float_第14张图片
普通文档流

BBBB绝对定位之后


position和float_第15张图片

可以看到,当BBBB绝对定位后,AAAA跑到BBBB的位置去了,说明BBBB在文档流中脱离了

position:fixed
与position:absolute的相同点

  1. 行内元素的display会变为block
  2. 覆盖到非定位元素上
  3. 脱离文档流

区别:
绝对定位的根元素可以被设置,可以是根元素也可以是已经定位的父元素;而固定定位只能根据根元素定位,当窗口改变时,元素和窗口的距离是不变的。

float:left|right|none

  1. 只能横向浮动,不能纵向浮动
  2. 元素设置float后,会脱离文档流,父元素高度塌陷
  3. 元素的display变为block
  4. 浮动元素的后一个元素会围绕着该浮动元素,文字围绕 图片。可以给后一个元素添加overflow:hidden ,使之成为BFC,这样就不会围绕浮动元素了。参见https://www.jianshu.com/p/ff73fa549e9a
  5. 浮动元素不会遮盖后一个元素;而position定位后,定位元素有可能会遮盖住非定位元素
  6. 浮动元素的前一个元素不会受影响,如果希望两个块元素并排显示,必须 两个都设置浮动

float和position同时使用时

  1. relative和float和top|left|right|bottom 同时使用时,先浮动到一定位置,再进行相对定位
  2. absolute和float和top 同时使用时,float失效

只设置float和relative时,没有top和left

position和float_第16张图片
float和relative

.wrapper{
    background-color: red;
    height: 200px;
    float: right;
    position: relative;
}

top=-100px, left=-100px

.wrapper{
    background-color: red;
    height: 200px;
    float: right;
    position: relative;
    top: 100px;
    left: 100px;
}
position和float_第17张图片
top left

设置position为absolute后,float失效,并没有浮动到右边

.wrapper{
    background-color: red;
    height: 200px;
    float: right;
    position: absolute;
    top: 100px;
    left: 100px;
}
position和float_第18张图片
absolute float

总结

position:relative
相对定位,相对于原来该元素在普通流中的位置重新定位,依旧在普通流中占据位置,没有脱离普通流,只是视觉上发生变化,覆盖到其他非定位元素上。
position:absolute
绝对定位:如果他的父元素都没有设置postion:relative|absolute,就根据根定位;否则根据设置了relative|absolute的最近的父元素定位;绝对定位元素脱离文档流,并使块级元素的宽变为自适应(auto),行内元素变为块级元素,覆盖到其他非定位元素上。
position:fixed
行内元素的display会变为block,覆盖到非定位元素上, 脱离文档流,固定定位只能根据根元素定位,当窗口改变时,元素和窗口的距离不变。
float:left|right|none

  1. 只能横向浮动,不能纵向浮动
  2. 脱离文档流,父元素高度塌陷
  3. 元素的display变为block
  4. 浮动元素的后一个元素会围绕着该浮动元素
  5. 浮动元素不会遮盖后一个元素
  6. 浮动元素的前一个元素不会受影响,如果希望两个块元素并排显示,必须 两个都设置浮动

你可能感兴趣的:(position和float)