新聞中心
你對hover在IE6下的問題是否了解,這里和大家分享一下hover在IE6下的問題及解決方法,相信本文介紹一定會讓你有所收獲。

hover在IE6下的問題
在處理CSS的機(jī)制上,IE總是有很多讓人吐血的舉動,但對于他們現(xiàn)在的改進(jìn)力度還是值得高興的。
就拿對偽類:hover的支持來說,IE7+終于添加了對a以外其它標(biāo)簽的支持。對于這樣的改進(jìn),當(dāng)然是要拍手稱快的,但在IE6下,:hover就連對a的支持都不是那么的盡如人意。下面就是我想簡單說的一個關(guān)于:hover在IE6及更早瀏覽器下的問題。
◆很多人可能都已經(jīng)知道了:hover在IE6及更早瀏覽器(以下稱IE6-)下的一些問題。我主要是想說一下形如a:hoverspan{}這樣的問題。
有的時候為了增加一些簡單的動態(tài)效果,常常會借助:hover的幫忙,比如我們時常會令鼠標(biāo)經(jīng)過鏈接時改變文字的顏色。如:
- a:hover{color:#F00;}
鼠標(biāo)經(jīng)過時改變我的顏色
是的,這將在所有的瀏覽器中都有效。但如果換成這樣:
- a:hoverem{color:#F00;}
鼠標(biāo)經(jīng)過時改變我的顏色
你會發(fā)現(xiàn)在IE6-下什么都沒有發(fā)生,我們的樣式失效了。對,就是這樣,應(yīng)該很多人都碰到過且已經(jīng)解決了這個問題。
是的,只需要再添加一個a:hover{}樣式就可以解決這個問題了,里面可以是zoom,padding,margin等屬性。如下:
- a:hover{zoom:1;}
- a:hoverem{color:#F00;}
鼠標(biāo)經(jīng)過時改變我的顏色
看著恢復(fù)了正常的效果,去想可能是因為什么造成:hover失效的。你可以使用zoom,display,padding等等屬性來搞定,于是想會不會是因為haslayout。恩,很有可能就是這樣。但你接著測試,會發(fā)現(xiàn),不論你在a:hover{}寫入任何屬性,color啊,font-size啊,overflow啊(甚至是不存在的屬性,如xx:yyy),都可以使之恢復(fù)正常。
測試到這里是不是有點(diǎn)目瞪口呆的感覺?對,我也是這樣的。至于原因是什么,我還不知道,或許有人知道。
◆一個a:hover的簡單例子:
運(yùn)行代碼框
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
:hover在IE6andearlier下的問題 - 下的:hover問題"/>
- #navul{zoom:1;overflow:hidden;list-style:none;margin:0;padding:0;background:#CCC;}
- #navli{float:left;width:100px;height:30px;line-height:30px;text-align:center;}
- #nava{color:#333;}
- #nava.en{display:none;}
- #nava:hover{display:block;background:#333;color:#CCC;}
- #nava:hover.en{display:inline;}
- #nava:hover.cn{display:none;}
首頁 Homepage 新聞 News 圖片 Picture 下載 Download 留言 Comment


咨詢
建站咨詢