[demo]為什么“+”沒有水平居中

原始代碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>為什么加號沒有水平居中</title>
</head>
<body>
<style>
    div{
        position: absolute;
        top:50%;
        left:50%;
        width:50px;
        height:50px;
        line-height: 50px;
        background: aqua;
        text-align: center;
        font-size: 329px;
    }
</style>
    <div>+</div>
</body>
</html>

解析

沒做特別的設(shè)定,行內(nèi)框自然從行框的左邊開始

我推測:由于css最先來自于排版。所以默認(rèn)字都是從左往右寫的,沒做特殊設(shè)定的時候,字體這個行內(nèi)框的左側(cè)有邊界問題,就是不能超過臨近行框的左側(cè)。字體小的時候,行內(nèi)框的元素居中,是因為也沒有碰到行框的左邊。但是當(dāng)字體不斷擴大的時候,直到碰壁(姑且叫做“左側(cè)碰壁假說”,沒找到相關(guān)資料)。由于前面所講的前提,碰壁之后沒有辦法,雖然text-align做了居中,但是左側(cè)碰壁假說的作用力會更強,因而導(dǎo)致文字被迫向右移。
當(dāng)然cyl提到左側(cè)碰壁并非不可破解的。利用負(fù)邊距可以使行框內(nèi)的行內(nèi)框打破這個規(guī)矩。

需要深入了解的

  1. 行內(nèi)框
  2. 行框
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 收聽音頻,戳鏈接,舊號itclan已暫停使用,歡迎關(guān)注微信itclanCoder公眾號可收聽更多音頻 前言 關(guān)于網(wǎng)...
    itclanCoder閱讀 8,349評論 3 30
  • 介紹一下行內(nèi)元素和塊級元素,這個很重要,因為有的屬性只能用于塊元素,而有的正好相反,在一定的情況下,它們也可以相互...
    吧啦啦小湯圓閱讀 817評論 0 3
  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補...
    _Yfling閱讀 14,144評論 1 92
  • ?這里涉及到行內(nèi)元素和塊級元素。 行內(nèi)元素和塊級元素可以相互轉(zhuǎn)換,比如用display來進行設(shè)置。 行內(nèi)元素(又叫...
    憶飛閱讀 682評論 0 0
  • 第一次來南京分公司出差 以后每個月中旬都要來南京分公司開會。 作為被散養(yǎng)的員工,是沒有歸屬感的 自己一個人在一個不...
    瓊語閱讀 454評論 0 1

友情鏈接更多精彩內(nèi)容