css中英文字母和漢字行高不同解決方案

來源:互聯網
上載者:User

  最近在寫一個css的時候遇到一個問題:英文字母和漢字的行高不一樣,導致在全漢字、全英文字母以及漢字字母混合時設定好的margin或padding 屬性出現偏差…當然這種情況之存在於IE瀏覽器,Safari、Google Chrome、Firefox、Opera均不存在類似的問題

  產生的原因:

  全漢字的時候:

  一般情況在選中文本可以看出漢字是上對齊的(具體表現是選中字型,從背景上看上去下面多了一部分,用css術語講就是產生了padding-bottom屬性,為了說明問題暫且就說存在padding屬性吧)。

  全英文字母的時候:

  類似於全漢字在全英文的情況下是下對齊,會出現類似padding-top的屬性。不管是全漢字還是全英文這時候的行高是一樣的。

  字母漢字混合:

  但是如果把漢字和英文字母混合在一起的時候就可以看出來差別了,這時候再選中所有字型就可以看出來這時候是的補白是 padding=padding-top+padding-bottom,也就是會多出來一個padding-top(也可以說是padding- bottom),一般字型在12px的情況下,多出來的部分大概是2px。

  解決辦法:

  更改字型:

  本來想使用line-height固定的,但是line-height是每一行的基準與基準之間的距離,又因為漢字的基準和英文字母是不同的,所以起不到作用,再說如果是用作導覽功能表只有一行還是沒有用的。

  這樣只有從字型上下手了,還真有一種字型可以解決這個問題,這個字型就是“simsun”,“simsun”就是傳說已久的“宋體”,在windows字型檔夾下“宋體”的檔案名稱就是“simsun”,他的兄弟“simhei”就是通常說的“黑體”。

  所以,解決辦法就是 把font-family設定成“simsun”,這可能會損失一些效果,沒辦法如果誰有更好的解決辦法可以指教一下。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.