首頁 >web前端 >css教學 >CSS 如何根據同級元素的屬性選擇性地定位元素?

CSS 如何根據同級元素的屬性選擇性地定位元素?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-28 04:43:13494瀏覽

How Can CSS Selectively Target Elements Based on a Sibling's Attribute?

CSS 如何根據另一個元素的狀態選擇元素

根據 DOM 中其他元素的狀態識別和定位元素可能具有挑戰性。由於組合器和選擇器語法的限制,CSS 選擇器提供的選項有限。雖然可以應用一些基本技術,包括父子關係和偽類的使用,但某些場景需要更高階的解決方案。

目前實現的限制

目前標準選擇器 3 缺乏父選擇器或前一個同級選擇器等基本功能。這些功能將大大擴展 CSS 建構和定位元素的能力。無法指定選擇器的主題也帶來了限制。

即將推出的 Selectors 4 的潛力

即將推出的 Selectors 4 標準旨在解決這些限制。 :has() 偽類別受 jQuery 功能的啟發,提供了靈活的解決方案。 :has() 允許根據父元素中是否存在其他元素來選擇元素。

解決問題

問題中提出的範例問題,其中需要基於另一個元素的資料狀態屬性來定位元素,可以使用選擇器中的:has( ) 來解決4:

section:has(> div[data-status~=finished]) + section > div:matches(.blink, .spin)

此選擇器透過使用:has() 選擇包含具有指定資料狀態的子div的部分,然後定位與.blink 或 .spin 類別。

以上是CSS 如何根據同級元素的屬性選擇性地定位元素?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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