我们先来看看CSS3 Api中对position属性的相关定义:

  • static:无特殊定位,对象遵循正常文档流。top,right,bottom,left等属性不会被应用。
  • relative:对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。
  • absolute:对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。
  • fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性定义。

怎么样,是不是还是很迷糊~~ 没关系,下面就从几个基础概念一一给大家详述:

什么是文档流?

将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流。

只有三种情况会使得元素脱离文档流,分别是:浮动、绝对定位和相对定位。

静态定位(static) :

static,无特殊定位,它是html元素默认的定位方式,即我们不设定元素的position属性时默认的position值就是static,它遵循正常的文档流对象,对象占用文档空间,该定位方式下,top、right、bottom、left、z-index等属性是无效的。

相对定位(relative) :

relative定位,又称为相对定位,从字面上来解析,我们就可以看出该属性的主要特性:相对。但是它相对的又是相对于什么地方而言的呢?这个是个重点,也是最让我迷糊的一个地方,现在让我们来做个测试,我想大家都会明白的:

(1) 初始未定位

[html] view plain copy
  1. /******初始*********/
  2. <style type="text/css">
  3. #first { width: 200px; height: 100px; border: 1px solid red; }
  4. #second{ width: 200px; height: 100px; border: 1px solid blue;}
  5. </style>
  6. <body>
  7. <div id="first"> first</div>
  8. <div id="second">second</div>
  9. </body>

初始原图:

(2) 我们修改first元素的position属性:

[html] view plain copy
  1. <style type="text/css">
  2. #first{ width: 200px; height: 100px; border: 1px solid red; position: relative; top: 20px; left: 20px;} /*add position*/
  3. #second{width: 200px; height: 100px; border: 1px solid blue;}
  4. </style>

相对偏移20px后:

 -- >> 虚线是初始的位置空间

现在看明白了吧,相对定位相对的是它原本在文档流中的位置而进行的偏移,而我们也知道relative定位也是遵循正常的文档流,它没有脱离文档流,但是它的top/left/right/bottom属性是生效的,可以说它是static到absoult的一个中间过渡属性,最重要的是它还占有文档空间,而且占据的文档空间不会随 top / right / left / bottom 等属性的偏移而发生变动,也就是说它后面的元素是依据虚线位置( top / left / right / bottom 等属性生效之前)进行的定位,这点一定要理解。

那好,我们知道了top / right / left / bottom 属性是不会对relative定位的元素所占据的文档空间产生偏移,那么margin / padding会让该文档空间产生偏移吗?答案是肯定的,我们一起来做个试验吧:

(3)   添加margin属性:

[html] view plain copy
  1. <style type="text/css">
  2. #first{width: 200px;height: 100px;border: 1px solid red;position: relative;top: 20px;left: 20px;margin: 20px;} /* add margin*/
  3. #second{width: 200px;height:100px;border: 1px solid blue;}
  4. </style>

设置margin:20px后:

对比一下,是不是就很清晰了,我们先将first元素外边距设为20px,那么second元素就得向下偏移40px,所以margin是占据文档空间!同理,大家可以自己动手测下padding的效果吧!

绝对定位(absoulte) :

absoulte定位,也称为绝对定位,虽然它的名字号曰“绝对”,但是它的功能却更接近于"相对"一词,为什么这么讲呢?原来,使用absoult定位的元素脱离文档流后,就只能根据祖先类元素(父类以上)进行定位,而这个祖先类还必须是以postion非static方式定位的, 举个例子,a元素使用absoulte定位,它会从父类开始找起,寻找以position非static方式定位的祖先类元素(注意,一定要是直系祖先才算哦~),直到<html>标签为止,这里还需要注意的是,relative和static方式在最外层时是以<body>标签为定位原点的,而absoulte方式在无父级是position非static定位时是以<html>作为原点定位。<html>和<body>元素相差9px左右。我们来看下效果:

(4) 添加absoulte属性:

[html] view plain copy
  1. <html>
  2. <style type="text/css">
  3. html{border:1px dashed green;}
  4. body{border:1px dashed  purple;}
  5. #first{ width: 200px;height: 100px;border: 1px solid red;position: relative;}
  6. #second{ width: 200px;height: 100px;border: 1px solid blue;position: absolute;top :0;left : 0;}
  7. </style>
  8. <body>
  9. <div id="first">relative</div>
  10. <div id="second">absoult</div>
  11. </body>
  12. </html>

效果图:

哈哈,看了上面的代码后,细心的朋友肯定要问了,为什么absoulte定位要加 top:0; left:0; 属性,这不是多此一举呢?

其实加上这两个属性是完全必要的,因为我们如果使用absoulte或fixed定位的话,必须指定 left、right、 top、 bottom 属性中的至少一个,否则left/right/top/bottom属性会使用它们的默认值 auto ,这将导致对象遵从正常的HTML布局规则,在前一个对象之后立即被呈递简单讲就是都变成relative,会占用文档空间,这点非常重要,很多人使用absolute定位后发现没有脱离文档流就是这个原因,这里要特别注意~~~

少了left/right/top/bottom属性不行,那如果我们多设了呢?例如,我们同时设置了top和bottom的属性值,那元素又该往哪偏移好呢?记住下面的规则:

  • 如果top和bottom一同存在的话,那么只有top生效。
  • 如果left和right一同存在的话,那么只有left生效。

既然absoulte是根据祖先类中的position非static元素进行定位的,那么祖先类中的margin/padding会不会对position产生影响呢?看个例子先:

(5) 在absoulte定位中添加margin / padding属性:

[html] view plain copy
  1. #first{width: 200px;height: 100px;border: 1px solid red;position: relative;margin:40px;padding:40px;}
  2. #second{width: 200px;height:100px;border: 1px solid blue;position: absolute;top:20px;left:20px;}
  3. <div id="first">first
  4. <div id="second">second</div>
  5. </div>

效果图:

看懂了,祖先类的margin会让子类的absoulte跟着偏移,而padding却不会让子类的absoulte发生偏移。总结一下,就是absoulte是根据祖先类的border进行的定位。

Note : 绝对(absolute)定位对象在可视区域之外会导致滚动条出现。而放置相对(relative)定位对象在可视区域之外,滚动条不会出现。

固定定位(fixed):

fixed定位,又称为固定定位,它和absoult定位一样,都脱离了文档流,并且能够根据top、right、left、bottom属性进行定位,但不同的是fixed是根据窗口为原点进行偏移定位的,也就是说它不会根据滚动条的滚动而进行偏移。

z-index属性:

z-index,又称为对象的层叠顺序,它用一个整数来定义堆叠的层次,整数值越大,则被层叠在越上面,当然这是指同级元素间的堆叠,如果两个对象的此属性具有同样的值,那么将依据它们在HTML文档中流的顺序层叠,写在后面的将会覆盖前面的。需要注意的是,父子关系是无法用z-index来设定上下关系的,一定是子级在上父级在下。

Note:使用static 定位或无position定位的元素z-index属性是无效的。

版权声明:转载原出处http://blog.csdn.net/chen_zw/article/details/8741365

转载于:https://www.cnblogs.com/zhimo/p/7268719.html

CSS中position属性( absolute | relative | static | fixed )详解相关推荐

  1. z-index失效的几种情况,父标签position属性为relative的时候,详解

    网上对这一方面解释的很多,我也不想把别人的抄过来.在这里是加上我对这些情况的理解还有我的一些疑惑,若有问题,请留言,谢谢!!!话不多说,进入正题: 文章重点:z-index失效的一类情况:父标签pos ...

  2. css中position属性(absolute/relative/static/fixed)

    css中position属性(absolute/relative/static/fixed): position:static   无特殊定位,是html元素默认的定位方式,对象遵循正常文档流.top ...

  3. HTML之position:absolute relative static fixed的区别和理解

    HTML之position:absolute relative static fixed的区别 在理解position:absolute relative static fixed的区别时,我们先需要 ...

  4. 【拼爹坑爹不比爹】深入理解css中position属性及z-index属性

    总结:拼爹坑爹不比爹 1,定位移动:距左上角left+top;(移动后对于移动前:如果值为负数,则直接换成整数:如果值为整数,则直接改变相对方向.) 2,单一父元素不设值,子z-index才奏效:&q ...

  5. 关于CSS中position属性和overflow属性的使用小结

    关于CSS中position属性和overflow属性的使用小结 position属性 用于设置某个元素的位置类型.取值类型可以有:static.relative.absolute.fixed.inh ...

  6. CSS中position属性值有哪些?

    CSS中position属性值有哪些? 1.position:relative;相对定位 1> 不影响元素本身特性(无论区块元素还是内联元素会保留其原本特性) 2> 不会使元素脱离文档流( ...

  7. CSS的定位 position属性的 absolute relative static fixed的区别及用法

    CSS中position一般是跟盒子结合做出效果的,浮动可以实现盒子在横向上的排列,但是如何实现在盒子上重叠另一个盒子的效果呢?就需要CSS的position来实现 position属性有四个,分别有 ...

  8. CSS中position属性(abusolute | relative | static | fixed)区别

    关于css3中position属性的定义: 转载于:https://www.cnblogs.com/tangjiao/p/9025934.html

  9. CSS中position属性(sticky)

    position的含义是指定位类型,取值类型可以有:static.relative.absolute.fixed.inherit和sticky,这里sticky是CSS3新发布的一个属性. 1.pos ...

最新文章

  1. 微信公众号为指定openid用户推送消息
  2. 程序员趣味读物:谈谈Unicode编码
  3. shopnc 商城源码阅读笔记--开篇概述
  4. mysql数据库被误删之后...
  5. 盘点那些面试中最常问的MySQL问题
  6. mybatis执行批量更新batch update 的方法(oracle,mysql)
  7. 面向过程与面向对象 程序设计
  8. mysql的压缩包安装_mysql 5.7.24 压缩包安装配置方法图文教程
  9. 基于JAVA+Servlet+JSP+MYSQL的二手房交易系统
  10. PS如何制作酷炫个性字母人像海报
  11. 媒体管理工具Media Encoder 2022 for Mac
  12. live2d_原画人插画教程,想知道live2d虚拟主播是怎么制作出来的吗?
  13. java入门编程(菜鸟教程)
  14. html 背景图片居中显示,CSS让背景图片居中显示的方法
  15. Qt连接MySql驱动加载失败问题解决方法
  16. Matplotlib取代minitab绘制正态分布图
  17. 彬彬股份牵手正极技术巨头 服装转型锂电
  18. 面试经历---广州YY(欢聚时代)
  19. 关于移动端的touch事件(touchstart, touchmove, touchend,touchcancel)
  20. 分析hanoi塔代码

热门文章

  1. Codeforces Round #104 (Div. 2) E DP(01背包模型) +组和+除法取模求逆元
  2. Asp.net无刷新调用后台实体类数据并以Json格式返回
  3. java类为什么要建两个class_ClassLoader的几个概念、类和对象的解释
  4. 数据预处理--噪声_为什么数据对您的业务很重要-以及如何处理数据
  5. Docker的使用(docker pull拉取镜像失败问题解决)
  6. 华北电力大学计算机图形学实验报告,华北电力大学计算机图形学实验报告分析.doc...
  7. 中值定理符号怎么读_微分、微分中值定理、泰勒公式
  8. (C++)1027 打印沙漏
  9. matlab 无序数对,MATLAB中sort函数对矩阵数进行排序
  10. 计算机二级周小丹,亲爱的设计丨周小丹:始终认真,才能保持“天真”