阅读 196

css中的position 的absolute和relative的区别以及span标签

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

  1. static:无特殊定位,对象遵循正常文档流。top,right,bottom,left等属性不会被应用。

  2. relative:对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义

  3. absolute:对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。

  4. fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性定义。、

具体解释如下: 什么是文档流? 将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流。

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

静态定位(static) :

static,无特殊定位,它是html元素默认的定位方式,即我们不设定元素的position属性时默认的position值就是static,它遵循正常的文档流对象,对象占用文档空间,该定位方式下,top、right、bottom、left、z-index等属性是无效的。 相对定位(relative) : relative定位,又称为相对定位,从字面上来解析,我们就可以看出该属性的主要特性:相对。但是它相对的又是相对于什么地方而言的呢?这个是个重点,也是最让我迷糊的一个地方,现在让我们来做个测试,我想大家都会明白的:

 #first {             width: 200px;             height: 100px;             border: 1px solid red;         }         #second {             width: 200px;             height: 100px;             border: 1px solid blue;         }          <div id="first"> first</div>     <div id="second">second</div> 复制代码

初始样式 在这里插入图片描述 ** 我们修改first元素的position属性:**

 #first {             width: 200px;             height: 100px;           background-color: red;             position: relative;             top: 20px;             left: 20px;                    }         #second {             width: 200px;             height: 100px;            background-color: black;         } 复制代码

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

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

(3)   添加margin属性:

     #first {             width: 200px;             height: 100px;           background-color: red;             position: relative;             top: 20px;             left: 20px;             margin: 20px;         }         #second {             width: 200px;             height: 100px;            background-color: black;         } 复制代码

在这里插入图片描述 对比一下,是不是就很清晰了,我们先将first元素外边距设为20px,那么second元素就得向下偏移40px,所以margin是占据文档空间!同理,大家可以自己动手测下padding的效果吧! 绝对定位(absoulte) : absoulte定位,也称为绝对定位,虽然它的名字号曰“绝对”,但是它的功能却更接近于"相对"一词,为什么这么讲呢?原来,使用absoult定位的元素脱离文档流后,就只能根据祖先类元素(父类以上)进行定位,而这个祖先类还必须是以postion非static方式定位的, 举个例子,a元素使用absoulte定位,它会从父类开始找起,寻找以position非static方式定位的祖先类元素(注意,一定要是直系祖先才算哦~),直到标签为止,这里还需要注意的是,relative和static方式在最外层时是以标签为定位原点的,而absoulte方式在无父级是position非static定位时是以作为原点定位。和元素相差9px左右。我们来看下效果:

在这里插入图片描述

     html {        background-color: green;     }     body {       background-color: purple;     }     #first {         width: 200px;         height: 100px;       background-color: red;         position: relative;     }     #second {         width: 200px;         height: 100px;        background-color: blue;         position: absolute;         top: 0;         left: 0;     } 复制代码

为什么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产生影响呢?看个例子先:

 #first {             width: 200px;             height: 100px;             background-color: red;             position: relative;             margin: 40px;             padding: 40px;         }         #second {             width: 200px;             height: 100px;             background-color: blue;             position: absolute;             top: 20px;             left: 20px;         }         <div id="first">first       <div id="second">second</div>   </div>   复制代码

在这里插入图片描述

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

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

先了解 解释一下display的几个常用的属性值,inline , block, inline-block

  1. inline(行内元素):

使元素变成行内元素,拥有行内元素的特性,即可以与其他行内元素共享一行,不会独占一行. 不能更改元素的height,width的值,大小由内容撑开. 可以使用padding上下左右都有效,margin只有left和right产生边距效果,但是top和bottom就不行. 2. block(块级元素): 使元素变成块级元素,独占一行,在不设置自己的宽度的情况下,块级元素会默认填满父级元素的宽度. 能够改变元素的height,width的值. 可以设置padding,margin的各个属性值,top,left,bottom,right都能够产生边距效果. 3.  inline-block(融合行内于块级): 结合了inline与block的一些特点,结合了上述inline的第1个特点和block的第2,3个特点. 再来说说span标签 原来CSS中的 width 属性并不总是有效的,如果对象是 inline 对象,width 属性就会被忽略span就是行内元素,Firefox 和 IE 是遵循CSS标准,因而直接设置span宽度会无效。 在span的CSS中增加display属性,将span设置为block类型的块级元素,这样宽度的确有效了,但把前后文字隔在不同行里面,这样其实span就完全变成了div。独占一行 将display:block设置成 display:inline-block就可,display:inline-block为不独占一行的块级元素


作者:YangYuY
链接:https://juejin.cn/post/7037664208791535652

 伪原创工具 SEO网站优化  https://www.237it.com/ 


文章分类
代码人生
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐