javascript - 为何margin:auto auto 不能上下左右对齐?
过去多啦不再A梦
过去多啦不再A梦 2017-06-24 09:42:38
0
4
1154

一个html中只有一个p。

<p class="test">
</p>

css1:

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

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

css2:

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

为何css2不可以使p.test上下左右居中?? 
请不要回答如何使他p.test上下左右居中,请回答为何margin:auto auto;不能上下左右居中?? 
过去多啦不再A梦
过去多啦不再A梦

全部回复(4)
大家讲道理

其他属性的使用值必须满足以下约束:

'margin-left' + 'border-left-width' + 'padding-left' + 'width' + 'padding-right' + 'border-right-width' + 'margin-right' = 包含块的宽度

如果 'margin-left' 和 'margin-right' 都为 'auto',则它们的使用值相等。这使元素相对于包含块的边缘水平居中。

下面是关于高度的:

如果 'margin-top' 或 'margin-bottom' 为 'auto',则它们的使用值为 0。如果 'height' 为 'auto',则高度取决于该元素是否有任何块级子元素以及是否它有填充或边框:

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

  • CSS规范

阿神

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

某草草

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

洪涛

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板