内联 SVG 上的 CSS 伪元素
使用 :before 等 CSS 伪元素将内容插入内联 SVG 元素并不简单。这是因为内联 SVG 被归类为替换元素,这些元素被明确排除在接收生成的内容之外。
替换元素上 :before 和类似伪元素的确切行为在 CSS 规范中没有明确定义。然而,人们普遍认为生成的内容不能直接应用于图像、嵌入式文档和小程序,其中包括内联 SVG。
此限制源于替换元素与文档流断开连接的事实。它们不参与格式化和布局过程,并且它们的内容被视为一个单元。因此,尝试在替换元素中附加生成的内容通常会导致意外或不一致的结果。
尽管在内联 SVG 上缺乏对 :before 的支持,但可能有一些解决方法。例如,可以创建一个外部 SVG 文件并使用
另一种方法是使用 CSS 来操纵 SVG 本身的样式。例如,可以使用 :nth-of-type 选择器来定位特定的 SVG 元素并向其应用样式。虽然此方法不直接添加生成的内容,但它允许对 SVG 的外观进行更细粒度的控制。
值得注意的是,CSS 的未来版本可能会引入新功能或有关使用的澄清被替换元素上的伪元素。在那之前,开发人员应该意识到这些限制并探索内联 SVG 样式的替代解决方案。
以上是像 `:before` 这样的 CSS 伪元素可以与内联 SVG 一起使用吗?的详细内容。更多信息请关注PHP中文网其他相关文章!