程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> css中英文字母和漢字行高不同解決方法

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

編輯:更多關於編程

      最近在寫一個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”,這可能會損失一些效果,沒辦法如果誰有更好的解決辦法可以指教一下。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved