请问relative设置偏移为百分比的效果
来源:2-5 position-relative
NeilSK
2018-01-17 14:44:13
请问我为relative的元素设置了top和left百分比,
left起作用, top不起作用, 这是怎么回事呢?
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<style type="text/css">
.parent{
width: 300px;
height: 300px;
border: 1px solid red;
background: gray;
position: relative;
top:50%;
left:50%;
}
.block{
height: 100px;
width: 100px;
border: 1px solid red;
background: blue;
position: absolute;
top:50%;
left:50%;
margin-left: -50px;
margin-top: -50px;
}
</style>
<body>
<div class="parent">
<div class="block"></div>
</div>
</body>
</html>4回答
你好,百分比这个值是以父级为参考的,就是说,是父级的百分之多少,但是这里parent的父级是body,而浏览器中,body是默认高度,并不是浏览器的可视区域高度。但是body的默认宽度是浏览器的可视区域宽度。所以,body的高度是0px,但是宽度是浏览器的宽度。
所以这里top设置百分比没有生效,但是left有效,建议:可给body设置下高度。例:可参考如下,设置百分比,也可以设置具体的高度。
html,body{
height:100%;
}祝学习愉快~
好帮手慕糖
2018-01-17
你好,是的,因为relative是以自身为参照。另:为什么left还有用,刚才已经有提到这个问题了哦,,而浏览器中,body是默认高度,并不是浏览器的可视区域高度。但是body的默认宽度是浏览器的可视区域宽度。所以,body的高度是0px,但是宽度是浏览器的宽度。宽度是浏览器的宽度,所以百分比生效,那么left就有效。也不是说top不能用,是可以使用的,只是百分比不行,你可以设置个固定数值还是可以的。
祝学习愉快~
好帮手慕糖
2018-01-17
你好,因为absolute是相对于浏览器窗口为参考的呀。absolute会向父级找参考,如果父级没有定位,会一直往外找,这里是由于都没有,那就相对于浏览器窗口来定位了。
祝学习愉快~
好帮手慕糖
2018-01-17
你好,建议:将全部分的代码粘贴过来,只有这部分,无法进行测试。
祝学习愉快~
相似问题