以前在項(xiàng)目里碰到過一個(gè)問題
input輸入框用一個(gè)背景圖模擬,設(shè)置height和line-height一樣的高度,使里面的輸入文字能夠居中,
在FF下出現(xiàn)的情況是:點(diǎn)擊input時(shí),輸入光標(biāo)其實(shí)上跟input的height一樣高,但當(dāng)開始輸入文字時(shí),光標(biāo)又變得跟文字一樣高,
chrome下光標(biāo)跟input的height一樣高,
而IE下光標(biāo)跟文字的大小一致。
一直沒弄明白為什么這樣子,今天聽羅浮宮里的同學(xué)一討論,才知道原因所在。
初步結(jié)論如下:
IE:不管該行有沒有文字,光標(biāo)高度與font-size一致。
FF:該行有文字時(shí),光標(biāo)高度與font-size一致。該行無文字時(shí),光標(biāo)高度與input的height一致。
Chrome:該行無文字時(shí),光標(biāo)高度與line-height一致;該行有文字時(shí),光標(biāo)高度從input頂部到文字底部(這兩種情況都是在有設(shè)定line-height的時(shí)候),如果沒有l(wèi)ine-height,則是與font-size一致。
解決的方案:
給input的height設(shè)定一個(gè)較小的高度,然后用padding去填充,基本上可以解決所有瀏覽器的問題
input{
height: 16px;
padding: 4px 0px;
font-size: 12px;
}
如對本文有疑問,請?zhí)峤坏浇涣髡搲瑥V大熱心網(wǎng)友會(huì)為你解答?。?點(diǎn)擊進(jìn)入論壇