这篇文章给大家分享的是有关CSS中相对定位和绝对定位的用法和区别是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
<强>一、相对定位强>
相对定位是指,该元素相对自己原来位置,偏移一定距离,元素可以通过顶部,底部,左侧左和右侧右属性来设置定位。<强>它相对的是它自己。强>
举例:大div里面包含5个小p, p给不同的类名,分别设置绝对定位和相对定位,看看他们有什么变化
没有设置定位的代码如下:
& lt; !DOCTYPE html> & lt; html> & lt; head> & lt;元charset=癠TF-8"祝辞 & lt; title> & lt;/title> & lt;风格类型=拔谋?css"比; *{填充:0;保证金:0;} .box{宽度:400 px;高度:500 px;边界:1 px固体黑色;保证金:50 px汽车;} .p1{宽度:100 px;高度:100 px;背景:红色;} .p2{宽度:100 px;高度:100 px;背景:橙色;} .p3{宽度:100 px;高度:100 px;背景:黄色;} .p4{宽度:100 px;高度:100 px;背景:绿色;} .p5{宽度:100 px;高度:100 px;背景:紫色;} & lt;/style> & lt;/head> & lt; body> & lt; div类=癰ox"祝辞 类& lt; p=皃1"祝辞11 & lt;/p> 类& lt; p=皃2"祝辞22 & lt;/p> 类& lt; p=皃3"祝辞33 & lt;/p> 类& lt; p=皃4"祝辞44 & lt;/p> 类& lt; p=皃5"祝辞55 & lt;/p> & lt;/div> & lt;/body> & lt;/html>
效果如图所示:
现在给第一个p标签设置相对定位,让他相对于自己原来的位置上偏移50 px,左边偏移50 px,具体代码如下:
。p1{宽度:100 px;高度:100 px;背景:红色,位置:相对;左:50 px;: 50 px;}
效果图:
对比前后效果图,有没有发现第一个p元素,它相对自己原来的位置发生了偏移,而且偏移以后,它依然占据原来的位置,后面的元素不会填补,如果有重叠,会重叠在它文档流元素之上,相对定位不会把其他元素挤掉。
<强>二,绝对定位强>
绝对定位是指,该元素相对它的父元素偏移一定距离,元素可以通过顶部,底部,左侧左和右侧右属性来设置定位。
注:相对的是父元素,而且这个父元素必须设置了位置属性。如果父元素没有位置属性,则从最近的父元素开始找,直到找到身体为止。
举例:给第三个p元素设置绝对定位,让其上偏移200 px,左偏移200 px,具体代码如下:
。p3{宽度:100 px;高度:100 px;背景:黄色;位置:绝对的,左:200 px;最高:200 px;}
效果图:
对比图1和图3可以发现,设置了绝对定位的元素,会脱离文档流,后面的元素会填补上来。因为第三个p标签的父元素为div,没有给div设置位置属性,所以它最终找到身体,相对于身体发生了偏移。
<强>三、相对定位和绝对定位的区别强>
<强>相对定位:强>相对自己原来的位置发生偏移,不会脱离文档流,不会删除它原来在文档流中占据的位置,且后面是元素不会填补空位
<>强绝对定位:强>相对它的父元素发生偏移(而且这个父元素必须设置了位置属性,如果父元素没有位置属性,则从最近的父元素开始找,直到找到身体为止),会脱离文档流,后面的元素会填补它原来的位置。
感谢各位的阅读!关于CSS中相对定位和绝对定位的用法和区别是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!