css⼦元素相对⽗元素进⾏定位
解决⽅案
在⽗元素中加⼊position:relative;
⼦元素中加⼊position:absolute; right:20px;
代码
html结构
<div id="div1">
<div id="div2"></div>
</div>
css
#div1{
absolute relativewidth:500px;height:500px;
background-color:darkgray;
position:relative;
}
#div2{
width:30px;height:30px;
background-color:red;
position:absolute;
right:20px;
}
效果
原理
浏览器渲染html,是有⽂档流的说法的,块级元素换⾏渲染,⾏内元素⾏内渲染,在这⾥,两个div都是块级元素,⼀个⽗,⼀个⼦,正常来说的渲染结果是⽗元素在浏览器左上⾓,⼦元素在⽗元素的左上⾓。
如果我们要对⼦元素相对⽗元素进⾏定位,就要⽤对position属性。
position属性值
属性值描述
absolute⽣成绝对定位的元素,相对于 static 定位以外的第⼀个⽗元素进⾏定位。
relative⽣成相对定位的元素,相对于其正常位置进⾏定位。
我们知道,要使⽤相对于⽗元素的定位,肯定要使⽤absolute,为什么直接使⽤absolute不起作⽤?因为使⽤absolute相对于⽗元素定位,对⽗元素有⼀个要求,就是⽗元素的position不能是static,如果⽗元素的position是static那么就继续向上查元素,知道不position不为static的元素,对这个元素进⾏相对定位,所以,需要将⽗元素的position设置为relative,这样做是没有影响的,因
为,relative只是相对于正常位置进⾏定位,正常位置就是所谓的⽂档流默认的输出位置,如果我们设置了position为relative⽽不设置偏移量x,y,那就相当于⽗元素的位置是没有变动的。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。