通过案例理解position:relative和position:absolute

摘要:
在学习了HTML之后,w3school觉得简单地咀嚼知识有点无聊,然后很容易忘记,于是就去特定的网站练习并填写自己不懂的知识。位置:相对和位置:绝对让我困惑了近一周。在互联网上找到的材料是混杂的。刚确认了“这样”的理解,我又看了另一份文件,发现“这样”理解是错误的。我一直在纠正并记录,最后整理出来供参考。请更正任何错误。下面的结

w3school过了HTML的知识之后,觉得要自己单纯地去啃知识点有点枯燥,然后自己也很容易忘记,所以便找具体的网站练手便补上不懂的知识点。position:relative和postion:absolute困扰了我快一个星期之久,网上找到的资料鱼龙混杂,刚确定“这样”的理解之后,看另一份资料,发现“这样”理解是错了,就这样不断更正,并记录下来,最终整理出这份,以备参阅。

若有错误,请指正。

下面的结果都是基于firefox38版本来测试的。

position:relative相对定位

1. 如何定位?
每个元素在页面的普通流中会“占有”一个位置,这个位置可以理解为默认值,而相对定位就是将元素偏离元素的默认位置,但普通流中依然保持着原有的默认位置。(在父级节点的content-box区定位,父级节点有文字的话,元素的默认位置则是紧随文字)
2. 不会改变行内元素的display属性。
3. 并没有脱离普通流,只是视觉上发生的偏移。
代码——

<body style='margin:0;padding:0;background:#BDD7EE;color:white;'>
<div class='contain' style='margin:10px;border:10px solid white;300px;background:#F8CBAD;padding:10px 0 0 10px;font-size:20px;font-weight:bold;'>
  <div class='one' style='50px;height:50px;background-color:#FFE699;top:-10px;left:0px;'></div>
  <div class='two' style='height:50px;color:#fff;background-color:#C5E0B4;'>position:relative定位测试</div>
</div>
</body>

显示—— 

通过案例理解position:relative和position:absolute第1张

给子元素one的style加上position:relative;后显示——

通过案例理解position:relative和position:absolute第2张

给父级元素contain的style加上文字后显示——

通过案例理解position:relative和position:absolute第3张

通过案例理解position:relative和position:absolute第4张

将one由div节点改为span节点,并加入文字“你好”之后显示——

<body style='margin:0;padding:0;background:#BDD7EE;color:white;'>
<div class='contain' style='margin:10px;border:10px solid white;300px;background:#F8CBAD;padding:10px 0 0 10px;font-size:20px;font-weight:bold;'>如果父级节点有文字的话...
  <span class='one' style='50px;height:50px;background-color:#FFE699;position:relative;top:-10px;left:0px;'>你好</span>
  <div class='two' style='height:50px;color:#fff;background-color:#C5E0B4;'>position:relative定位测试</div>
</div>
</body>

通过案例理解position:relative和position:absolute第5张

position:absolute绝对定位

1. 如何定位浮动?

  • 设置了TRBL
    相对最近的设定了position:relative/absolute的父(祖先)节点的padding-box的区进行定位(忽略文字),找不到符合条件的父(祖先)节点,则相对浏览器窗口进行定位。

  • 没有设置了TRBL
    则默认浮动,默认浮动在父级节点的content-box区。

2. 不管是块级元素还是行内元素,应用了position:absolute之后,display为block:

  • 可以设置width和height

  • 没有设置的话,width默认为auto

3. 脱离文档流,容器(父)元素将得不到脱离普通流的子元素高度

代码——

<body style='margin:10px;300px;color:white;background-color:#BDD7EE;'>
<div style='background-color:#F8CBAD;padding-top:10px;'>祖先元素
  <div style='background-color:#FFE699;border:10px solid white;padding-top:10px;'>父级元素
    <div style='background-color:#C5E0B4;'>子元素</div>
  </div>
</div>
</body>

显示----

通过案例理解position:relative和position:absolute第6张

给子元素的style加上position:absolute;top:0px;left:0px;后显示——

通过案例理解position:relative和position:absolute第7张

 给子元素的style加上position:absolute;top:0px;后显示——

通过案例理解position:relative和position:absolute第8张

注释:应用了position:absolute之后之设置了top,所以子元素的top紧贴浏览器窗口的top(距离为0px),因为没有设置left,所以子元素左边就默认父级元素content-box区的左侧进行定位(没应用position:absolute之前左侧该在哪个位置就在那个位置)
给子元素的style加上position:absolute;后显示——

通过案例理解position:relative和position:absolute第9张

案例:理解应用了position:absolute的元素没有设置TRBL的话,则默认浮动在父级节点的content-box区

用一句通俗易懂的话来说就是,它该在哪个位置就在哪个位置,只不过不占位而已。
先理解下上面示例代码的显示图,以及给自己元素加上position:absolute后的显示图。

通过案例理解position:relative和position:absolute第10张

给子元素的样式加上:display:inline;我们看看如果子元素是内联元素的话会如何显示。

通过案例理解position:relative和position:absolute第11张

假如有两个同级块级元素,看看第一个子元素和第二个子元素分别应用position:absolute后的效果如何。

<div style='background-color:#F8CBAD;padding-top:10px;'>祖先元素
  <div style='background-color:#FFE699;border:10px solid white;padding-top:10px;'>父级元素
      <div style='background-color:#62C292;'>子元素(上)</div>
      <div style='background-color:#C5E0B4;'>子元素(下)</div>
  </div>
</div>

通过案例理解position:relative和position:absolute第12张

如果这两个同级块级元素都应用了position:absolute;这两个元素会进行重叠,子元素(下)显示在前面,那是因为默认代码靠后的元素的z-index比较大。

通过案例理解position:relative和position:absolute第13张

 上面的案例中,将第二个子级元素换为内联元素,子元素(下)的起点位置并没有改变。

 通过案例理解position:relative和position:absolute第14张

 试试给代码中的第一个元素的style加上display:inline;看看上面的子元素是内联元素的话会如何显示。

<div style='background-color:#F8CBAD;padding-top:10px;'>祖先元素
  <div style='background-color:#FFE699;border:10px solid white;padding-top:10px;'>父级元素
      <div style='background-color:#62C292;display:inline;'>子元素(上)</div>
      <div style='background-color:#C5E0B4;'>子元素(下)</div>
  </div>
</div>

通过案例理解position:relative和position:absolute第15张

  现在调换下应用position:absolute的位置

代码: 

<div style='background-color:#F8CBAD;padding-top:10px;'>祖先元素
  <div style='background-color:#FFE699;border:10px solid white;padding-top:10px;'>父级元素
      <div style='background-color:#C5E0B4;'>子元素(上)</div>
      <div style='background-color:#62C292;'>子元素(下)</div>
  </div>
</div>

通过案例理解position:relative和position:absolute第16张

第一个子元素是内联元素的话——

<div style='background-color:#F8CBAD;padding-top:10px;'>祖先元素
  <div style='background-color:#FFE699;border:10px solid white;padding-top:10px;'>父级元素
      <div style='background-color:#C5E0B4;display:inline;'>子元素(上)</div>
      <div style='background-color:#62C292;'>子元素(下)</div>
  </div>
</div>

通过案例理解position:relative和position:absolute第17张

 综上:不管是块级元素还是内联元素应用position:absolute并且不设置TRBL,它都会默认在父级元素的content-box区浮动。原来的起点位置也是应用绝对定位后的起点位置,只不过如果应用了position:absolute的内联元素左边也有内联元素的话,它的起点位置会变得更靠前,直到紧挨左边内联元素的边界。

综合案例:看看position:relative和position:absolute的综合效果

沿用position:absolute的案例代码——

<body style='margin:10px;300px;color:white;background-color:#BDD7EE;'>
<div style='background-color:#F8CBAD;padding-top:10px;'>祖先元素
  <div style='background-color:#FFE699;border:10px solid white;padding-top:10px;'>父级元素
    <div style='background-color:#C5E0B4;'>子元素</div>
  </div>
</div>
</body>

在上面代码的基础上分别应用以下的定位后看看效果,并理解。

通过案例理解position:relative和position:absolute第18张

案例诊断:

    • 给祖先div加上"position:relative;"以及给子元素加上
      "position:absolute;top:0px;left:0px;"

通过案例理解position:relative和position:absolute第19张

 给父级div加上"position:relative;"以及给子元素加上
"position:absolute;top:0px;left:0px;"

 通过案例理解position:relative和position:absolute第20张

 给祖先和父级div加上"position:relative;"以及给子元素加上
"position:absolute;top:0px;left:0px;"

 通过案例理解position:relative和position:absolute第21张

  给祖先div加上"position:absolute;"以及给子元素加上

"position:absolute;top:0px;left:0px;"

 通过案例理解position:relative和position:absolute第22张

 给父级div加上"position:absolute;"以及给子元素加上
"position:absolute;top:0px;left:0px;"

通过案例理解position:relative和position:absolute第23张

给祖先和父级div加上"position:absolute;"以及给子元素加上
"position:absolute;top:0px;left:0px;"

通过案例理解position:relative和position:absolute第24张

 我们看到,确实是消除了环绕浮动元素环绕的影响,position:absolute的优先级高,所以float元素被遮住了,并不是消失了。另外看到contain元素的高度不受子元素的影响了,因为它们都脱离文档流了。

参考颜色

通过案例理解position:relative和position:absolute第25张

应用:消除环绕浮动元素的影响

父级,position:relative(不设TRBL)
子级,第一个div的float:left;第二个div的position:absolute(不设TRBL)
因为第二个子级div元素默认会在父级元素的content-box区浮动,它可以消除上一个同级子级div元素的环绕浮动影响。
案例代码——

<div class='contain' style='margin:10px;300px;background:#F8CBAD;padding:10px 0 10px;color:white;'>
  <div class='one' style='30px;height:30px;background-color:#FFE699;float:left;'></div>
  <div class='two' style='color:#fff;background-color:#C5E0B4;'>position:absolute消除浮动环绕的影响测试</div>
</div>

显示--

通过案例理解position:relative和position:absolute第26张

给父级元素加上position:relative,给第二个子级元素加上position:absolute后,显示——

通过案例理解position:relative和position:absolute第27张

转载自:https://segmentfault.com/a/1190000006924181

免责声明:文章转载自《通过案例理解position:relative和position:absolute》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇根据CPU核心数确定线程池并发线程数dockerfile构建redis下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Django中CSS加载background url('')问题

Django中CSS加载background url('')问题 在django中, 默认CSS中如果有 background url('images/a.jpg') 这类的属性,会被django当成URL来解析 这样会造成找不到该文件的问题。 所以为了解决这个问题,首先需要配置setting.py, 配置STATICFILES_DIRS STATIC...

在页面布局中,怎么实现水平居中和垂直居中?

先给出DOM结构 <div class="box"><div class="box-center"> </div> </div> 一:水平居中 若是行内元素,给其父元素设置text-align:center即可实现行内元素水平居中 若是块级元素,该元素设置margin:0 auto即可(元素需要定宽...

event、fly.js、购物车特效

 先总结下区别: #鼠标相对于浏览器窗口可视区域的X,Y坐标(窗口坐标),可视区域不包括工具栏和滚动条。 event.clientX、event.clientY #鼠标相对于document文档区域的x、y坐标。这2个属性不是标准属性,但得到了广泛支持。IE8-的事件中没有这2个属性。 event.pageX、event.pag...

coding.net------WEBHOOK自动部署实战

使用WebHook自动部署项目今天在laravist.com看到了这个 Webhook 自动部署Git项目 这个教学视频,以前自己也想做这样做一个利用Git WebHook的自动化部署,但总是不成功,今天看到视频就想着再次尝试一下,虽然有视频参考但还是遇到了一些坑,在这里我写下自己的部署过程.注:1.我是在de style="box-sizing: bo...

ggplot2绘图入门系列之三:位置调整与条形图

    位置调整(Position adjustments)是针对同一图层内元素的位置进行微调的方法。它包括五种设置,分别是stack、dodge、fill、identity、jitter。 我们用条形图来展示其用法,仍使用mpg数据集,其中用到的变量是class,即生产汽车的类型,以及year生产年份。下面的条形图是将各类型的汽车数量进行汇集,并以年份作...

关于圆角的实现以及鼠标移入显示二级菜单的兼容处理!

在这时碰到了一个圆角边框的问题,以前的代码是在每个页面写一个固定结构的div,使用背景图片来实现圆角边框。代码结构大致如下: .top_border{background:url(topborder.png);} .left_border{background:url(leftborder.png);} .right_border{background:u...