可以分几种情况考虑:
data:image/s3,"s3://crabby-images/8bdc1/8bdc1dbbdf39f9d5546fddc87b5e8ea9bd6104ff" alt=""
(1)块状元素的水平垂直居中:
data:image/s3,"s3://crabby-images/662cd/662cd66454e5ccfd38c2029bfa28b2315ceedeef" alt=""
利用绝对定位和负margin,这时要给块级元素设置width,height;
data:image/s3,"s3://crabby-images/1cb07/1cb07115c3800408ebb8c0130afd21a8c17989af" alt=""
data:image/s3,"s3://crabby-images/4624d/4624d66f0469617d000c5c0e0fed9257a55a4b3e" alt=""
利用绝对定位+transform:translate属性,可以使不知块级元素宽高的情况下实现居中。
data:image/s3,"s3://crabby-images/21e36/21e36388a447009aee6f93739da9eac5f4cfa8df" alt=""
data:image/s3,"s3://crabby-images/ab01e/ab01e2a87f3c17190f2c9b7f362f558fc9a8e4da" alt=""
利用flex盒子,在父元素上设置align-items和justify-items即可实现子块状元素的居中。
还有:对于块状元素,仅仅只实现水平居中的话,可以用margin:0 auto;实现
(2)行内元素的水平垂直居中
data:image/s3,"s3://crabby-images/c738b/c738b01ab71ea6029f223a5ab3b806fea29945ae" alt=""
data:image/s3,"s3://crabby-images/987fd/987fdfcb5c9eca166c417bdc09b7574352f2cf6f" alt=""
在父盒子上使用text-align:center;在子行内元素上设置line-height等于父盒子的height。
data:image/s3,"s3://crabby-images/67eb9/67eb918eade3966ca45c458fd910ac4fd59152c0" alt=""
将父盒子设置为table类型;子行内元素设置为table-cell类型;设置行内元素的vertical-align;可实现与上面相同的效果。
(3)最后可以使用flex盒子
data:image/s3,"s3://crabby-images/11a3f/11a3f7299be535831dea13e861d1a01f2fe4bd80" alt=""
网友评论