我在网络上GOOGLE能够在视窗内,水平和垂直方向都置中的表单:
例如以下:
https://jsfiddle.net/lueichun/bq92w7oa/1/
一开始是<body>下一层的div(<div class="back">)
这个div的css是:
.back {
background: #e2e2e2;
width: 100%;
/* height:100%;*/
position: absolute;
top: 0;
bottom: 0;
}
这样可以让这div填满整个body。我的理解是:
将该div的position设成absolute,就可让该div的位置相对于body,
然后设定top、bottom都=0,即可让该div的位置,相对于body,顶端跟底端都是重叠的。
而设定width=100%,则让该div横跨整个body。
这样该div就和body重叠,也就填满body了。
然后设定再下一层的div(<div class="div-center">):
.div-center {
width: 600px;
height: 400px;
background-color: #fff;
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
margin: auto;
}
我想说上一个div是利用position: absolute;top: 0;bottom: 0;
就能设定跟body相对的位置。
那我这边如果只单纯设定position,以及left=0、right=0等值,
该div却位在左上角,看起来right=0、bottom=0没有作用。
非得要将上margin=auto,整个div才会置中。
请问如果只是单纯设定position、left、right、top这些属性,为何在这个div就失效呢?
而且margin=auto不是用来设定水平方向置中而已吗?
为何在这边也会影响垂直方向置中呢?
感谢