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

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;width:300px;background:#F8CBAD;padding:10px 0 0 10px;font-size:20px;font-weight:bold;'>
  <div class='one' style='width: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>

显示——

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


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


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

<body style='margin:0;padding:0;background:#BDD7EE;color:white;'>
<div class='contain' style='margin:10px;border:10px solid white;width:300px;background:#F8CBAD;padding:10px 0 0 10px;font-size:20px;font-weight:bold;'>如果父级节点有文字的话...
  <span class='one' style='width: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: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;width: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>

显示——


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


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


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


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

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


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


假如有两个同级块级元素,看看第一个子元素和第二个子元素分别应用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:absolute;这两个元素会进行重叠,子元素(下)显示在前面,那是因为默认代码靠后的元素的z-index比较大。


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


试试给代码中的第一个元素的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: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>

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

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

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

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

<body style='margin:10px;width: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>

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


案例诊断:

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


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


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


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


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


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


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

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

<div class='contain' style='margin:10px;width:300px;background:#F8CBAD;padding:10px 0 10px;color:white;'>
  <div class='one' style='width: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后,显示——



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

参考颜色

修改记录

  • 2016.12.23增补案例理解默认浮动
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,747评论 1 92
  • 深入理解傅里叶变换Mar 12, 2017 这原本是我在知乎上对傅立叶变换、拉普拉斯变换、Z变换的联系?为什么要进...
    价值趋势技术派阅读 5,749评论 2 2
  • 为div设置样式 背景 颜色背景 圆角背景 ie支持不是很好 边框背景 阴影背景 ie支持不是很好 圆形背景...
    Longwide阅读 399评论 0 1
  • 简约且低饱和度的色调,是深受人们喜爱的家装风格 2018年室内设计流行趋势的报告中,简约柔和风在未来依旧流行 因为...
    默lang阅读 336评论 0 0
  • 携程攻略社区阅读 268评论 0 0