网页前端后台技巧(CSS+HTML)让前端飞Web前端之路

position和float

2018-04-21  本文已影响17人  椰果粒

position

position有四个值:static(默认),relative,absolute,fixed

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

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)

<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,相对于最近的定位元素定位

结论

  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元素未定位,正常的文档流中

<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的相同点

  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

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

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

猜你喜欢

热点阅读