CSS中的绝对定位(absolute)误区
这几天在慕课上看视频学习,偶然听到几个老师都说:CSS绝对定位在没有其他有除static定位的包含块的情况下是以body进行定位,如果要想相对当前元素的父元素来定位,父元素一定要设置position:relative。注意,前面一句是没有问题的,在没有父元素设置定位的话,默认就是以body来定位的,但是后面一句,要想相对父元素定位,父元素必须设置相对定位(relative),根据我的开发经验和查阅相关资料确认后发现,这是不对的。 (总结一句话:父元素relative 子元素absolute )
正确的理解姿势是:
相对定位:相对于块级元素(或行内块)自身位置进行定位;
绝对定位:绝对定位的盒子是相对于离它最近的一个已定位的盒子进行定位的(默认是body);
注意css描述的绝对定位概念,没有说明是离他最近的一个已相对定位的盒子进行定位的,所以离他最近的盒子的定位可以是相对定位(relative)和绝对定位(absolute)的,但是在开发中,一般是父盒子设置相对定位的,但是不代表只能是相对定位,举个栗子:
HTML:
1 <div class="father"> 2 <div class="son"></div> 3 </div>
CSS:
1 .father{
2 width: 300px;
3 height: 300px;
4 background-color: orange;
5 position: absolute;
6 top:50%;
7 left:50%;
8 margin-top: -150px;
9 margin-left: -150px;
10 }
11 .son{
12 width: 100px;
13 height: 100px;
14 background-color: pink;
15 position: absolute;
16 left:0;
17 top:0;
18 }
.father元素绝对定位是相对body的,这个没问题,主要看.son元素,他自身设置绝对定位,父元素.father也有绝对定位,你觉得这个子元素会相对body定位还是父元素来定位呢?

结果为:子元素是相对于有绝对定位的父元素来定位的,而不是body;
----------------------------------------------------------------------------自己实践------------------------------------------------------------------------------------------




浙公网安备 33010602011771号