css 水平垂直居中 & vertical-align
前言:这是笔者学习之后自己的理解与整理。如果有错误或者疑问的地方,请大家指正,我会持续更新!
已知宽度的元素居中
position定位 + margin负值
绝对定位 + 4个方向全部`0px` + `margin:auto` 可以做到基于父容器水平垂直居中。
绝对定位 + 左50% + margin-left:宽度一半的负值,可以做到水平居中,右也可以。
绝对定位 + 上50% + margin-top:高度一半的负值,可以做到垂直居中,底部也可以。
<style type="text/css"> * { padding: 0; margin: 0; } .wrapper { width: 500px; height: 500px; background: #f90; left: 0; right: 0; top: 0; bottom: 0; position: absolute; margin: auto; /*绝对定位 + 4个方向全部0px + margin:auto 可以做到基于父容器水平垂居中*/ /*如果只需要垂直居中,那可以把left和right删掉,并且水平居中的方法也很多*/ } .content { width: 100px; height: 200px; background: #0f8; position: absolute; /*position: absolute基于第一个不是position:static的父级元素定位*/ left: 50%; top: 50%; margin-left: -50px; margin-top: -100px; /*绝对定位 + 左50% + margin左:宽度一半的负值 可以做到水平居中 右也可以*/ /*绝对定位 + 上50% + margin上:高度一半的负值 可以做到垂直居中 底部也可以*/ } </style> <div class="wrapper"> <span class="content"></span> </div>
未知宽度的元素居中
position定位 + transform:translate(-50%,-50%)
<style type="text/css"> * { padding: 0; margin: 0; } .wrapper { width: 500px; height: 500px; background: #f90; left: 0; right: 0; top: 0; bottom: 0; position: absolute; margin: auto; /*绝对定位 + 4个方向全部0px + margin:auto 可以做到基于父容器水平垂居中*/ /*如果只需要垂直居中,那可以把left和right删掉,并且水平居中的方法也很多*/ } .content { width: 100px; height: 200px; background: #0f8; position: absolute; /*position: absolute基于第一个不是position:static的父级元素定位*/ left: 50%; top: 50%; transform: translate(-50%, -50%); /*transform变化、使...变形、转换;transform属性应用于元素的2D或3D转换。这个属性允许你将元素移动,旋转,缩放,倾斜*/ /*translate平移,是transform的属性值的一部分*/ /*transition过渡、转变;可多个样式的变换效果*/ } </style> <div class="wrapper"> <span class="content"></span> </div>
`div`中`img`图片垂直居中
可以用`vertical-align:middle`,但是这个属性只有在`inline-block`类型(`inline`也有影响)的元素身上起作用。
方法一:图片`vertical-align:middle` + 父元素的`height`与`line-height`一致
<style type="text/css"> * { padding: 0; margin: 0; } .wrapper { height: 300px; line-height: 300px; width: 300px; margin: 100px auto; background: #f90; text-align: center; } .wrapper img { width: 150px; vertical-align: middle; } </style> <div class="wrapper"> <img src="images/1.jpg" alt="美女" title="美女" /> </div>
方法二:父元素设置`display:table-cell和vertical-align`
<style type="text/css"> * { padding: 0; margin: 0; } .wrapper { width: 300px; height: 300px; background: #f90; text-align: center; vertical-align: middle; display: table-cell; } .wrapper img { width: 150px; } </style> <div class="wrapper"> <img src="images/1.jpg" alt="美女" title="美女" /> </div>