position
position有四个值:static(默认),relative,absolute,fixed
postion 可以继承
普通文档流就是根据元素是行内元素 还是块级元素依次排列显示。
position不同的取值主要体现在元素是否脱离文档流
和是否改变行内元素的display属性值
两个方面
下面是一个普通文档流:各元素按照顺序依次排列,每个元素都有一个“默认位置”
<div class="wrapper"> <div class="a">A</div> <div class="b">B</div> <div class="c">C</div></div>.a,.b,.c{ width:150px; height: 100px; } .a{ background-color: red; } .b{ background-color: green; } .c{ background-color: yellow; }
原始图
position:static
是默认的方式,所有元素在默认情况下都是static
position:relative
相对定位,相对于原来该元素在普通流中的位置重新定位,依旧在普通流中占据位置,没有脱离普通流,只是视觉上发生变化
.b{ background-color: green; position: relative; top: 50px; left: 100px; }
相对定位
相对定位不会使行内元素的display发生变化
<span class="d">DDDDD</span> .d{ background-color: gold; position: relative; top: 50px; left: 100px; width: 300px; }
相对定位,行内元素
从上图中可见,.d没有设置上宽 ,所以相对定位并没有改变行内元素的display属性值
position:absolute
绝对定位:如果他的父元素都没有设置postion:relative|absolute,就根据根定位;否则根据设置了relative|absolute的父元素定位;绝对定位元素脱离文档流,并使块级元素的宽变为自适应(auto),元素的位置与文档流无关,也不占据文档空间。位置是相对于它最近的非static祖先元素的位置决定的。
<div class="body">BODY <div class="wrapper">WRAPPER <div class="b">BBBB</div> </div> </div>.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;*/ }
原始图
放开.b的注释后,因为.b绝对定位,其余元素无定位,则.b相对于整个页面的根<body>标签定位,BBBB宽度自适应
我们可以看到这里BBBB距离BODY最底边有一定的距离,是因为他相对于根定位,而<body>自身有一定的margin和padding
给.wrapper添加postion:relative后,就相对.wrapper定位了,BBBB本身宽度自适应
给.wrapper添加postion:absolute后,相对.wrapper定位,且WRAPPER和BBBB本身宽度自适应
给.body添加postion:relative后,相对.body定位,且BBBB本身宽度自适应
给.body添加postion:absolute后,相对.body定位,且BBBB,WRAPPER,BODY宽度自适应
body wrapper 均为relative,则相对于最近的元素定位
BODY WRAPPER均为absolute,则都宽度自适应,相对于最近的元素定位
BODY是relative , WRAPPER是absolute,相对于最近的元素定位
BODY是absolute ,WRAPPER是relative,相对于最近的定位元素定位
结论
块状元素在position(relative/static)的情况下width为100%,但是设置了position: absolute之后,width变成auto(会受到父元素的宽度影响)
元素设置了position: absolute之后,如果没有设置top、bottom、left、right属性的话,浏览器会默认设置成auto,而auto的值则是该元素的“默认位置”,也就是只设置absolute,还是在默认位置
如果定位元素的父元素都没有设置绝对或者相对定位,那么该元素就根据根元素定位
如果定位元素的父元素有绝对或者相对定位,那么就相对最近的定位父元素定位
position:absolute的行内元素会改变display,变为块级元素
覆盖其他非定位元素
脱离文档流
验证绝对定位会脱离文档流
此时BBBB元素未定位,正常的文档流中
<div class="body">BODY <div class="wrapper">WRAPPER <div class="b">BBBB</div> <div class="a">AAAA</div> </div> </div> .a{ width: 100px; height: 100px; background-color: #ccc; }
普通文档流
BBBB绝对定位之后
可以看到,当BBBB绝对定位后,AAAA跑到BBBB的位置去了,说明BBBB在文档流中脱离了
position:fixed
与position:absolute的相同点
行内元素的display会变为block
覆盖到非定位元素上
脱离文档流
区别:
绝对定位的根元素可以被设置,可以是根元素也可以是已经定位的父元素;而固定定位只能根据根元素定位,当窗口改变时,元素和窗口的距离是不变的。
float:left|right|none
只能横向浮动,不能纵向浮动
元素设置float后,会脱离文档流,父元素高度塌陷
元素的display变为block
浮动元素的后一个元素会围绕着该浮动元素,文字围绕 图片。可以给后一个元素添加overflow:hidden ,使之成为BFC,这样就不会围绕浮动元素了。参见https://www.jianshu.com/p/ff73fa549e9a
浮动元素不会遮盖后一个元素;而position定位后,定位元素有可能会遮盖住非定位元素
浮动元素的前一个元素不会受影响,如果希望两个块元素并排显示,必须 两个都设置浮动
float和position同时使用时
relative和float和top|left|right|bottom 同时使用时,先浮动到一定位置,再进行相对定位
absolute和float和top 同时使用时,float失效
只设置float和relative时,没有top和left
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; }
top left
设置position为absolute后,float失效,并没有浮动到右边
.wrapper{ background-color: red; height: 200px; float: right; position: absolute; top: 100px; left: 100px; }
absolute float
总结
position:relative
相对定位,相对于原来该元素在普通流中的位置重新定位,依旧在普通流中占据位置,没有脱离普通流,只是视觉上发生变化,覆盖到其他非定位元素上。
position:absolute
绝对定位:如果他的父元素都没有设置postion:relative|absolute,就根据根定位;否则根据设置了relative|absolute的最近的父元素定位;绝对定位元素脱离文档流,并使块级元素的宽变为自适应(auto),行内元素变为块级元素,覆盖到其他非定位元素上。
position:fixed
行内元素的display会变为block,覆盖到非定位元素上, 脱离文档流,固定定位只能根据根元素定位,当窗口改变时,元素和窗口的距离不变。
float:left|right|none
只能横向浮动,不能纵向浮动
脱离文档流,父元素高度塌陷
元素的display变为block
浮动元素的后一个元素会围绕着该浮动元素
浮动元素不会遮盖后一个元素
浮动元素的前一个元素不会受影响,如果希望两个块元素并排显示,必须 两个都设置浮动
作者:椰果粒
链接:https://www.jianshu.com/p/d8e0dbd7e870