首頁 >web前端 >css教學 >為什麼 :hover 和多個相鄰兄弟選擇器會導致 Safari 和 Chrome 中出現錯誤?

為什麼 :hover 和多個相鄰兄弟選擇器會導致 Safari 和 Chrome 中出現錯誤?

Patricia Arquette
Patricia Arquette原創
2024-10-24 03:42:301056瀏覽

Why Do :hover and Multiple Adjacent-Sibling Selectors Cause Bugs in Safari and Chrome?

帶有:hover 和多個相鄰兄弟選擇器的Safari 和Chrome 錯誤

在Web 開發中,使用:hover 偽類別和相鄰-兄弟選擇器通常受到Safari、Chrome、Opera 和Firefox 等主流瀏覽器的支援。例如,以下程式碼如預期運作:

a:hover + div {}

但是,當新增多個相鄰同級選擇器時,Webkit 瀏覽器(包括Safari 和Chrome)會表現出意外行為:

div:hover + a + div {}

在這種情況下,Webkit 無法如預期地套用樣式。

解決此錯誤的解決方法是在body 元素上使用樣式聲明來創建微妙的動畫效果:

body { -webkit-animation: bugfix infinite 1s; }

@-webkit-keyframes bugfix { 
  from { padding: 0; } 
  to { padding: 0; } 
}

此動畫沒有可見效果,但會觸發樣式重新計算,從而允許Webkit 瀏覽器正確套用:hover 和相鄰同級選擇器樣式。

以下是示範解決方法的範例:http://jsfiddle。 net/jalbertbowdenii/ds2yY/1/.

透過採用此技術,您可以克服 Webkit 錯誤並確保不同瀏覽器之間的行為一致。

以上是為什麼 :hover 和多個相鄰兄弟選擇器會導致 Safari 和 Chrome 中出現錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn