首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法使用React覆盖SVG图标的fill属性

无法使用React覆盖SVG图标的fill属性
EN

Stack Overflow用户
提问于 2021-01-17 03:55:18
回答 1查看 132关注 0票数 0

我有一堆从Figma导出的图标,我想使用<use>标签的好处在这些图标周围创建一个包装器组件。

所以我创建了一个包含所有符号的SVG文件,以便通过它们的id来定位它们。

问题是,我不能覆盖重用图标上的fill属性。经过大量阅读,我知道我应该使用CSS继承,因为重用的元素位于阴影DOM中,并且它的属性不能像往常一样被访问。

仅出于调试目的,我将其中一个图标的源代码直接复制粘贴到组件中(而不是使用导入机制),令人惊讶的是,它可以工作。

代码如下:

icon.svg

代码语言:javascript
复制
<svg xmlns="http://www.w3.org/2000/svg">
  <symbol id="ic">
    <path fill="#000" d="M81,40.933c0-4.25-3-7.811-6.996-8.673c-0.922-5.312-3.588-10.178-7.623-13.844  c-2.459-2.239-5.326-3.913-8.408-4.981c-0.797-3.676-4.066-6.437-7.979-6.437c-3.908,0-7.184,2.764-7.979,6.442  c-3.078,1.065-5.939,2.741-8.396,4.977c-4.035,3.666-6.701,8.531-7.623,13.844C22.002,33.123,19,36.682,19,40.933  c0,2.617,1.145,4.965,2.957,6.589c0.047,0.195,0.119,0.389,0.225,0.568l26.004,43.873c0.383,0.646,1.072,1.04,1.824,1.04  c0.748,0,1.439-0.395,1.824-1.04L77.82,48.089c0.105-0.179,0.178-0.373,0.225-0.568C79.855,45.897,81,43.549,81,40.933z   M49.994,11.235c2.164,0,3.928,1.762,3.928,3.93c0,2.165-1.764,3.929-3.928,3.929s-3.928-1.764-3.928-3.929  C46.066,12.997,47.83,11.235,49.994,11.235z M27.842,36.301c0.014,0,0.027,0,0.031,0c1.086,0,1.998-0.817,2.115-1.907  c0.762-7.592,5.641-13.791,12.303-16.535c1.119,3.184,4.146,5.475,7.703,5.475c3.561,0,6.588-2.293,7.707-5.48  c6.664,2.742,11.547,8.944,12.312,16.54c0.115,1.092,1.037,1.929,2.143,1.907c2.541,0.013,4.604,2.087,4.604,4.631  c0,1.684-0.914,3.148-2.266,3.958H25.508c-1.354-0.809-2.268-2.273-2.268-3.958C23.24,38.389,25.303,36.316,27.842,36.301z   M50.01,86.723L27.73,49.13h44.541L50.01,86.723z"/>
  </symbol>
</svg>

LocalIcon.css

代码语言:javascript
复制
.icon {
    width: 100px;
    height: 125px;
}

use.ic-1 {
    fill: skyblue;
}
use.ic-2 {
    fill: #FDC646;
}

svg path {
    fill: inherit;
}

LocalIcon.js

代码语言:javascript
复制
import React, { FC } from 'react';
import Icons from '../../icons/ic.svg';
import './LocalIcon.css';

const LocalIcon = ({ name, color, size }) => (
  // <svg fill={color} width={size} height={size}>
  //   <use className="icon" xlinkHref={`${Icons}#Icon/Heart/Filled`}/>
  // </svg>
  <>
    <svg>
      <symbol id="ic">
        <path fill="#000" d="M81,40..."/>
      </symbol>
    </svg>
    <svg className='icon' viewBox='0 0 100 125'>
      <use className='ic-1' href={`${Icons}#ic`} x='0' y='0' /> // This one is still black
    </svg>
    <svg className='icon' viewBox='0 0 100 125'>
      <use className='ic-2' href='#ic' x='0' y='0' />   // This one works
    </svg>
  </>
);

有人知道我做错了什么吗?这与我导入文件的方式有什么关系吗?非常感谢你的帮助。

EN

回答 1

Stack Overflow用户

发布于 2021-01-17 04:55:22

为了应用您的CSS规则,您需要将SVG代码中的任何fill规则更改为fill:'inherit'。否则,SVG样式将覆盖您的CSS样式。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65754050

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档