SVG图片通过img引入修改颜色

通过 <img> 标签引入的 SVG 图片默认无法直接通过 CSS 修改颜色,但可通过以下方法实现颜色修改:


1. 使用 CSS filterdrop-shadow 技巧

原理 ‌:通过滤镜生成彩色投影,偏移后覆盖原图,隐藏原图并显示投影。

实现步骤‌:

  1. <img> 放入父容器并设置 overflow: hidden
  2. <img> 应用 filter: drop-shadow 生成彩色投影
  3. 使用 transform 偏移原图,使投影覆盖原位置
css 复制代码
htmlCopy Code
<div class="svg-container">
  <img src="icon.svg" class="svg-icon">
</div>
css 复制代码
cssCopy Code
.svg-container {
  width: 50px;
  height: 50px;
  overflow: hidden;
}
.svg-icon {
  filter: drop-shadow(#ff0000 50px 0); /* 红色投影 */
  transform: translateX(-50px); /* 偏移原图 */
}

适用场景‌:单色修改,需固定尺寸容器。


2. 使用 mask-image 方案

原理 ‌:将 SVG 作为遮罩,通过 background-color 控制颜色。

实现步骤‌:

  1. mask-image 引入 SVG
  2. 通过 background-color 设置颜色
css 复制代码
htmlCopy Code
<div class="svg-mask"></div>
css 复制代码
cssCopy Code
.svg-mask {
  width: 50px;
  height: 50px;
  background-color: #00ff00; /* 绿色 */
  -webkit-mask-image: url(icon.svg);
  mask-image: url(icon.svg);
}

优点‌:无需偏移,支持动态颜色。


3. 使用 JavaScript 动态注入 SVG

原理 ‌:通过脚本将 SVG 内联到 DOM,直接修改属性。

实现步骤 ‌(以 svg-inject 库为例):

  1. 安装库:npm install @iconfu/svg-inject
  2. <img> 标签添加 onload 事件:
ini 复制代码
htmlCopy Code
<img src="icon.svg" onload="SVGInject(this)" class="svg-injected">
css 复制代码
cssCopy Code
.svg-injected path {
  fill: blue; /* 直接修改填充色 */
}

优点‌:支持多色修改,保留矢量特性。


4. 转换为 Base64 内联

原理 ‌:将 SVG 转为 Base64 编码,直接修改代码中的颜色值。

实现步骤‌:

  1. 使用工具将 SVG 转为 Base64
  2. 替换 fillstroke 属性值
css 复制代码
htmlCopy Code
<img src="data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL..." alt="SVG">

缺点‌:需手动修改代码,灵活性低。


注意事项

  • 浏览器兼容性 ‌:mask-image 需前缀,drop-shadow 在旧版浏览器可能失效14。
  • 性能影响‌:复杂滤镜可能增加渲染负担6。

根据项目需求选择合适方案,优先推荐 mask-image 或 JavaScript 注入

相关推荐
拜晨10 小时前
使用motion实现小宇宙贴纸墙效果
前端·交互设计
拜晨10 小时前
使用motion实现小宇宙节目广场的效果
前端·交互设计
知花实央l11 小时前
【Web应用实战】 文件上传漏洞实战:Low/Medium/High三级绕过(一句话木马拿webshell全流程)
前端·学习·网络安全·安全架构
华仔啊11 小时前
JavaScript + Web Audio API 打造炫酷音乐可视化效果,让你的网页跟随音乐跳起来
前端·javascript
鸡吃丸子11 小时前
SEO入门
前端
檀越剑指大厂11 小时前
【Nginx系列】Tengine:基于 Nginx 的高性能 Web 服务器与反向代理服务器
服务器·前端·nginx
是你的小橘呀11 小时前
深入理解 JavaScript 预编译:从原理到实践
前端·javascript
uhakadotcom11 小时前
在使用cloudflare workers时,假如有几十个请求,如何去控制并发?
前端·面试·架构
风止何安啊11 小时前
栈与堆的精妙舞剧:JavaScript 数据类型深度解析
前端·javascript
用户479492835691512 小时前
Chrome DevTools MCP:让 AI 助手直接操作浏览器开发工具
前端·javascript·chrome