css3 - css的一個(gè)多行文字水平居中的問(wèn)題
問(wèn)題描述
打算做一個(gè)css多行文字垂直居中的demo,自己如下這樣寫(xiě):
html:<p class='align_box_2'><span class='align_word'> 這里顯示多行文字。這里顯示多行文字。</span></p>css: <style>.align_box_2{display:table-cell; width:550px; height:1.14em; padding:0 0.1em; border:4px solid #beceeb; color:#069; font-size:10em; vertical-align:middle;}.align_box_2 span.align_word{display:inline-block; font-size:0.1em; vertical-align:middle;border: 1px solid red;} </style>
最后的樣式(chrome52):
大概是居中偏下一點(diǎn),如果是多行文字也是會(huì)偏下,想請(qǐng)教一下這是為什嚒?
(備注:自己知道flex等其它解決方式,但是想知道這個(gè)是怎么回事...)
問(wèn)題解答
回答1:p里面有個(gè)font-size:10em;的屬性,不知用意是什么?偏下如此嚴(yán)重大致就是因?yàn)樗斐傻摹D憧梢試L試修改這個(gè)值,值越大,偏下越多。稍微說(shuō)下原因,vertical-align:middle這一屬性對(duì)inline和inline-block元素的居中對(duì)齊并非文字中線字體渲染都是按照英文標(biāo)準(zhǔn)渲染,你是否記得曾經(jīng)的英語(yǔ)作業(yè)本那種四線三格。vertical-align:middle的居中是按照四線三格的第三根線對(duì)齊的
稍微改了一下相應(yīng)的代碼,用height撐開(kāi)p的高度,取消了font-size,單位用的px你看看
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Document</title> <style>.align_box_2{display:table-cell; width:550px; height:110px; padding:0 10px; border:4px solid #beceeb; color:#069; vertical-align:middle;}.align_box_2 span.align_word{display:inline-block;font-size: 12px; vertical-align:middle;border: 1px solid red;} </style> </head><body> <p class='align_box_2'><span class='align_word'>這里顯示多行文字。這里顯示多行文字。這里顯示多行文字。這里顯示多行文字。這里顯示多行文字。這里顯示多行文字。這里顯示多行文字。</span> </p></body></html>回答2:
用flex 布局試試。http://codepen.io/seven_zhang...
<p class='demo'> this is aaaaaaaaaaaaaaaaaaaaa test!</p>
.demo { height:200px; width:200px; border:1px solid blue; display:flex; align-items:center; }
回答3:建議使用display:flex多欄多列布局,詳細(xì)介紹請(qǐng)見(jiàn):http://www.360doc.com/content...如果你問(wèn)的是vertical-align:middle為什么不是垂直居中的話,可以看看這篇博客:http://www.zhangxinxu.com/wor...
相關(guān)文章:
1. [python2]local variable referenced before assignment問(wèn)題2. 求救一下,用新版的phpstudy,數(shù)據(jù)庫(kù)過(guò)段時(shí)間會(huì)消失是什么情況?3. mysql - 如何在有自增id的情況下,讓其他某些字段能不重復(fù)插入4. python小白,關(guān)于函數(shù)問(wèn)題5. django - Python error: [Errno 99] Cannot assign requested address6. angular.js - 百度支持_escaped_fragment_嗎?7. java - 線上應(yīng)用,如果數(shù)據(jù)庫(kù)操作失敗的話應(yīng)該如何處理?8. node.js - win 下 npm install 遇到了如下錯(cuò)誤 會(huì)導(dǎo)致 無(wú)法 run dev么?9. python小白 關(guān)于類(lèi)里面的方法獲取變量失敗的問(wèn)題10. Python2中code.co_kwonlyargcount的等效寫(xiě)法
