CSS可以使用align-items属性让文字上下居中,将文字所在容器定义为flex容器,然后设置align-items:center;样式即可让文字上下居中。
css设置文字上下居中:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <style> #mAIn { width: 220px; height: 300px; border: 1px solid black; display: -webkit-flex; /* Safari */ -webkit-align-items: center; /* Safari 7.0+ */ display: flex; align-items: center; } #main div { -webkit-flex: 1; /* Safari 6.1+ */ flex: 1; } </style> </head> <body> <div id="main"> 上下居中文字 </div> <p><b>注意:</b> Internet Explorer 10 及更早版本浏览器不支持 align-items 属性。</p> <p><b>注意:</b> Safari 7.0 及更新版本通过 -webkit-align-items 属性支持该属性。</p> </body> </html>
效果如下:
align-items 属性定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式。
提示:使用每个弹性对象元素的 align-self 属性可重写 align-items 属性。
属性值为center:
元素位于容器的中心。
弹性盒子元素在该行的侧轴(纵轴)上居中放置。(如果该行的尺寸小于弹性盒子元素的尺寸,则会向两个方向溢出相同的长度)。