javascript - 为何margin:auto auto 不能上下左右对齐?
问题描述
一个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;不能上下左右居中??
问题解答
回答1: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规范
回答2:这是个好问题,那我问你,当一行存在两个元素的时候,你可以左右居中吗?同理当你的上下都可能有元素存在的情况下你要浏览器怎么去计算对应元素应该存在的位置?
回答3:不能吧,上下对齐如果不用flex布局,没啥太好的办法。virtical–align也不太好用!
回答4:不能,如果想上下左右对居中的话,推荐使用flex布局,其次是table,table-cell或者定位
相关文章:
1. win10系统 php安装swoole扩展2. html按键开关如何提交我想需要的值到数据库3. PHPExcel表格导入数据库怎么导入4. index.php错误,求指点5. html5和Flash对抗是什么情况?6. vue.js - Vue 如何像Angular.js watch 一样监听数据变化7. 关于Java引用传递的一个困惑?8. javascript - bootstrap table固定列之后宽度无法对齐怎么解决?9. html5 - 我引用的是花瓣网上的图片,在自己电脑上可以正常显示(状态码200),但在别人电脑上是403forbid,有大神知道是什么吗?10. 我毕业以后在工作之余学了 PHP,都是自学 现在在找这方面的工作 求前辈指导学习方向 工作常用的知识
