素材牛VIP会员
为何margin:auto auto 不能上下左右对齐?
 贝***0  分类:Html5  人气:1192  回帖:5  发布于6年前 收藏

一个html中只有一个div。

<div class="test">
</div>

css1:

.test{
    width:200px;
    height:200px;
    border:1px solid red;
    margin:0 auto;
    }

css1可以使div.test左右居中。

css2:

.test{
    width:200px;
    height:200px;
    border:1px solid red;
    margin:auto auto;
    } 

为何css2不可以使div.test上下左右居中?? 
请不要回答如何使他div.test上下左右居中,请回答为何margin:auto auto;不能上下左右居中?? 

讨论这个帖子(5)垃圾回帖将一律封号处理……

Lv3 码奴
18***30 Linux系统工程师 6年前#1

不能,如果想上下左右对居中的话,推荐使用flex布局,其次是table,table-cell或者定位

Lv7 码师
陌***4 软件测试工程师 6年前#2

你可以把div变成内联块,然后在父元素加个line-height. line-height的值等于父元素的高度,那么它的子元素就可以垂直居中了

Lv6 码匠
捂***功 移动开发工程师 6年前#3

The following constraints must hold among the used values of the other properties:

'margin-left' + 'border-left-width' + 'padding-left' + 'width' + 'padding-right' + 'border-right-width' + 'margin-right' = width of containing block

If both 'margin-left' and 'margin-right' are 'auto', their used values are equal. This horizontally centers the element with respect to the edges of the containing block.

下面是关于高度的:

If 'margin-top', or 'margin-bottom' are 'auto', their used value is 0. If 'height' is 'auto', the height depends on whether the element has any block-level children and whether it has padding or borders:

因为规范就是这么规定的算法,浏览器就是这么实现的。

  • CSS规范

Lv3 码奴
xi***xu 职业无 6年前#4

这是个好问题,那我问你,当一行存在两个元素的时候,你可以左右居中吗?同理当你的上下都可能有元素存在的情况下你要浏览器怎么去计算对应元素应该存在的位置?

Lv7 码师
封***榜 职业无 6年前#5

不能吧,上下对齐如果不用flex布局,没啥太好的办法。virtical–align也不太好用!

 文明上网,理性发言!   😉 阿里云幸运券,戳我领取