首頁 >web前端 >css教學 >像 `:before` 這樣的 CSS 偽元素可以與內嵌 SVG 一起使用嗎?

像 `:before` 這樣的 CSS 偽元素可以與內嵌 SVG 一起使用嗎?

Susan Sarandon
Susan Sarandon原創
2024-11-29 06:31:14890瀏覽

Can CSS Pseudo-Elements Like `:before` Be Used with Inline SVGs?

內聯 SVG 上的 CSS 偽元素

使用 :before 等 CSS 偽元素將內容插入內嵌 SVG 元素並不簡單。這是因為內聯 SVG 被歸類為替換元素,這些元素被明確地排除在接收產生的內容之外。

替換元素上 :before 和類似偽元素的確切行為在 CSS 規範中沒有明確定義。然而,人們普遍認為生成的內容不能直接應用於圖像、嵌入式文件和小程序,其中包括內聯 SVG。

此限制源自於替換元素與文件流斷開連接的事實。它們不參與格式化和佈局過程,並且它們的內容被視為一個單元。因此,嘗試在替換元素中附加產生的內容通常會導致意外或不一致的結果。

儘管在內聯 SVG 上缺乏對 :before 的支持,但可能有一些解決方法。例如,可以建立一個外部 SVG 檔案並使用 將其插入 HTML 文件中。標籤。然後,這個外部 SVG 可以像其他元素一樣透過 CSS 接收產生的內容。

另一種方法是使用 CSS 來操縱 SVG 本身的樣式。例如,可以使用 :nth-of-type 選擇器來定位特定的 SVG 元素並向其套用樣式。雖然此方法不會直接添加生成的內容,但它允許對 SVG 的外觀進行更細粒度的控制。

值得注意的是,CSS 的未來版本可能會引入新功能或有關使用的澄清被替換元素上的偽元素。在那之前,開發人員應該意識到這些限制並探索內聯 SVG 樣式的替代解決方案。

以上是像 `:before` 這樣的 CSS 偽元素可以與內嵌 SVG 一起使用嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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