为了账号安全,请及时绑定邮箱和手机立即绑定

为什么要写margin:-50px 0 0 -50px;直接写margin:-50px;结果是一样的呀?​(2)

将box{width: 200px;height: 200px;}改为.box{width: 300px;height: 150px;},问题还是存在

(代码如下:)?

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>已知宽高实现盒子水平垂直居中</title>
 <div class="box">
     <div class="one">one</div>
     <div class="two">two</div>
     <div class="three">three</div>
     <div class="four">four</div>
</div>

<style>
.box {
    width: 300px;
    height: 150px;
    border: 1px black solid;
    position:relative;
}
.box div {
    width: 100px;
    height: 100px;
    position:absolute;
}
.one{
    border: 1px red solid;
    top:50%;
    right:50%;
    /*margin-top:-50px;*/
    /*margin-right:-50px;*/
    margin-bottom:-50px;
    margin-left:-50px;
}
.two{
    border: 1px blue solid;
    top:50%;
    left:50%;
    margin-top:-50px;
    margin-right:-50px;
    margin-bottom:-50px;
    margin-left:-50px;
}
.three{
    border: 1px orange solid;
    bottom:50%;
    right:50%;
    margin-top:-50px;
    margin-right:-50px;
    margin-bottom:-50px;
    margin-left:-50px;
}
.four{
    border: 1px green solid;
    bottom:50%;
    left:50%;
    margin-top:-50px;
    margin-right:-50px;
    margin-bottom:-50px;
    margin-left:-50px;
}

</style>

</html>

http://img4.sycdn.imooc.com/5f13afd00001f9fe11670657.jpg

http://img3.sycdn.imooc.com/5f13afd00001f82511580660.jpg


正在回答

4 回答

嗯嗯,我试也是这样的。但我想知道这是为什么呢?

0 回复 有任何疑惑可以回复我~

这是我的多次尝试后得到的结论:

当设置绝对定位的方向为top和left时,margin中的bottom和right的值就毫无作用,只是习惯上设为0,其实设置margin:-100px也是同样的效果,甚至margin: -100px -200px 300px -100px效果也是一样的,只要关心margin中的top和left。

当绝对定位方向为bottom和right时,同上。


5 回复 有任何疑惑可以回复我~

啥意思?是这样。。。http://img1.sycdn.imooc.com//5f13e254000144fb13310780.jpg

0 回复 有任何疑惑可以回复我~

margin: 0 auto 不就居中了。。。

1 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

为什么要写margin:-50px 0 0 -50px;直接写margin:-50px;结果是一样的呀?​(2)

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信