踩坑日记 svg 颜色更改失败

前言

最近入职了新公司,感觉还不错,还在熟悉阶段。

然后刚来两天就遇到一个小问题,封装的svg组件在处理某个svg图片时,无法修改svg图片的颜色。

类似这种:

鼠标移动上去之后

但是有一个svg图片,在svg组件中使用时,无法改变其svg图片颜色。

问题排查

在了解svg图片为什么无法改变颜色之前,我们先了解svg的使用环境。

这个svg图片是使用在一个封装的svg组件中,使用如下:

html 复制代码
<svg>
    <use xlink:href="SVG路径"></use>
</svg>

改变颜色的方法则是通过修改svg标签的style属性,如:

html 复制代码
<svg style={fill: color}>
    ...
</svg>

可以看到这里的样式是通过 style 直接注入的

那这个样式最后为什么会影响svg图片呢?又为什么某些svg图片不会被这些样式影响呢?

所以这里我们来看看异常的svg图片的代码是怎么样子的(无关紧要的内容已删除)。

首先svg是矢量图,浏览器通过svg图片中的路径信息,进行绘制,因此这里修改的实际上就是 fill 的值即填充的颜色

然后通过阅读代码,我们可以看到path 路径中,默认补充了fill的值,而我们通过style的方法修改fill 是影响path的父元素,通过继承父亲样式的方式,以期更改样式,如果默认补充了fill的值,那么就不会使用基础的内容。

因此无法影响svg颜色的原因就确定了,因为默认填充了颜色。

问题解决

原因排查清楚之后,问题解决也就轻而易举了。

我们可以将默认的fill填充提取到svg标签中,Path通过继承svg标签的fill来确定颜色,保证svg组件更改颜色的时候,可以更改到fill填充色。

改动大致如下:

总结

到此问题修复完毕,如果用户朋友们遇到svg无法改变颜色的情况,不妨尝试排查下这方面。

下次见!

相关推荐
qq_177767371 天前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头88211 天前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
天人合一peng1 天前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling1 天前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐1 天前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区1 天前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO1 天前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121381 天前
Vuex介绍
前端·javascript·vue.js
We་ct1 天前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480061 天前
【无标题】
开发语言·前端·javascript