为何 SVG 作为 CSS 背景时,fill 属性不支持十六进制颜色?
SVG 作为 CSS 背景时,fill 属性为何不支持十六进制颜色?
在将 SVG 用作 CSS 背景时,您可能会发现 fill 属性接受蓝字等颜色名称,却无法识别 #acd123 等十六进制颜色。然而,将相同的 SVG 作为 HTML 标签使用时,十六进制 fill 颜色可以正常显示。
原因很可能是因为:
解决方法:
由于十六进制颜色直接设置在 fill 属性中不可行,您可以尝试以下替代方案:
- 使用 RGB() 表示法:将十六进制颜色转换为 RGB 形式,例如 #acd123 => rgb(172, 209, 35)。这种方法将允许 CSS 正确识别颜色并将其应用于 SVG 填充。
- 使用 CSS 变量:在 CSS 中定义一个 CSS 变量来存储十六进制颜色,然后将其引用到 fill 属性中。这样做将绕过 CSS 对 SVG 内部属性的限制,因为变量前缀化后的十六进制颜色被视为 CSS 值,而不是 SVG 值。
以上就是为何 SVG 作为 CSS 背景时,fill 属性不支持十六进制颜色?的详细内容,更多请关注其它相关文章!