Google Chrome input的height和line-height設置為相同的比默認高度高的值時,當input控件獲得焦點並且沒有輸入內容時,input中的光標會占滿整個input控件(如果設置了padding-top或padding-bottom則會低於整個控件的高度),但輸入內容后光標高度又馬上恢復為字體的高度,效果圖和案例代碼如下,那么怎么解決這個問題呢?
<!DOCTYPE html> <html> <head> <title>line-height</title> <meta charset="utf-8" /> <style> *{outline:none;} body,input,textarea,button{ font-size:200%; font-family:arial; } input{ height:2.4em; line-height:2.4em; padding:0 0.1em; } </style> </head> <body> <input type="text" placeholder="想輸入什么?" autofocus /> </body> </html>
Google Chrome input line-height Bug 解決方案
- 去掉 inline-height 屬性,但這會導致IE6/7/8瀏覽器中input的光標偏移到input左上方,在標准瀏覽器(特指Google Chrome, Firefox, Opera, Safari, IE 9+)中,如果對input設置了height,而沒有設置line-height,瀏覽器會自動使input中的內容和光標垂直居中對齊,而且光標的高度和字的高度一樣。IE8及更早版本非標准,必須將height和line-height設置為相同的值才能使input中的內容垂直居中對齊,這樣修正了一個瀏覽器,卻弄壞了更多瀏覽器,真是得不償失,請看下面的完美解決方案。
- 增加一條樣式 input[type="text"]:focus{line-height: normal},這會導致IE8中input光標偏移到input左上方,IE6/7/9及更新版本正常顯示。只要再加上一條CSS hack,即可解決問題,實現所有主流瀏覽器兼容:input[type="text"]:focus{line-height: normal; line-height: 2.4em\9;},其中的2.4em就是最初設置的值。
- Google Chrome 39已經修正了這個BUG,這才是最完美的解決方案。