最近在寫(xiě)一個(gè)css的時(shí)候遇到一個(gè)問(wèn)題:英文字母和漢字的行高不一樣,導(dǎo)致在全漢字、全英文字母以及漢字字母混合時(shí)設(shè)置好的margin或padding 屬性出現(xiàn)偏差…當(dāng)然這種情況之存在于IE瀏覽器,Safari、Google Chrome、Firefox、Opera均不存在類(lèi)似的問(wèn)題。
css
產(chǎn)生的原因:
全漢字的時(shí)候:
一般情況在選中文本可以看出漢字是上對(duì)齊的(具體表現(xiàn)是選中字體,從背景上看上去下面多了一部分,用css術(shù)語(yǔ)講就是產(chǎn)生了padding-bottom屬性,為了說(shuō)明問(wèn)題暫且就說(shuō)存在padding屬性吧)。
全英文字母的時(shí)候:
類(lèi)似于全漢字在全英文的情況下是下對(duì)齊,會(huì)出現(xiàn)類(lèi)似padding-top的屬性。不管是全漢字還是全英文這時(shí)候的行高是一樣的。
字母漢字混合:
但是如果把漢字和英文字母混合在一起的時(shí)候就可以看出來(lái)差別了,這時(shí)候再選中所有字體就可以看出來(lái)這時(shí)候是的補(bǔ)白是 padding=padding-top+padding-bottom,也就是會(huì)多出來(lái)一個(gè)padding-top(也可以說(shuō)是padding- bottom),一般字體在12px的情況下,多出來(lái)的部分大概是2px。
解決辦法:
更改字體:
本來(lái)想使用line-height固定的,但是line-height是每一行的基線與基線之間的距離,又因?yàn)闈h字的基線和英文字母是不同的,所以起不到作用,再說(shuō)如果是用作導(dǎo)航菜單只有一行還是沒(méi)有用的。
這樣只有從字體上下手了,還真有一種字體可以解決這個(gè)問(wèn)題,這個(gè)字體就是“simsun”,“simsun”就是傳說(shuō)已久的“宋體”,在windows字體文件夾下“宋體”的文件名就是“simsun”,他的兄弟“simhei”就是通常說(shuō)的“黑體”。
所以,解決辦法就是 把font-family設(shè)置成“simsun”,這可能會(huì)損失一些效果,沒(méi)辦法如果誰(shuí)有更好的解決辦法可以指教一下。