Css 如何更改svg元素的颜色?

Css 如何更改svg元素的颜色?,css,svg,Css,Svg,我想修改SVG的颜色,但到目前为止我还没能做到。我把它放在CSS里,但不管怎样,我的图像总是黑色的 我的代码: 。更改我的颜色{ 填充:绿色; } 您不能以这种方式更改图像的颜色。如果将SVG作为图像加载,则无法使用CSS或Javascript更改其在浏览器中的显示方式 如果要更改SVG图像,必须使用、或使用内联加载它 如果您想使用页面中的技术,您需要Modernizer库,在这里您可以检查SVG支持并有条件地显示或不显示回退图像。然后可以内联SVG并应用所需的样式 见: #时间3图标{ 填

我想修改SVG的颜色,但到目前为止我还没能做到。我把它放在CSS里,但不管怎样,我的图像总是黑色的

我的代码:

。更改我的颜色{
填充:绿色;
}

您不能以这种方式更改图像的颜色。如果将SVG作为图像加载,则无法使用CSS或Javascript更改其在浏览器中的显示方式

如果要更改SVG图像,必须使用
或使用
内联加载它

如果您想使用页面中的技术,您需要Modernizer库,在这里您可以检查SVG支持并有条件地显示或不显示回退图像。然后可以内联SVG并应用所需的样式

见:

#时间3图标{
填充:绿色;
}
.我的svg备用{
显示:无;
}
.no svg.my svg alternate{
显示:块;
宽度:100px;
高度:100px;
背景图片:url(image.png);
}

您不能以这种方式更改图像的颜色。如果将SVG作为图像加载,则无法使用CSS或Javascript更改其在浏览器中的显示方式

如果要更改SVG图像,必须使用
或使用
内联加载它

如果您想使用页面中的技术,您需要Modernizer库,在这里您可以检查SVG支持并有条件地显示或不显示回退图像。然后可以内联SVG并应用所需的样式

见:

#时间3图标{
填充:绿色;
}
.我的svg备用{
显示:无;
}
.no svg.my svg alternate{
显示:块;
宽度:100px;
高度:100px;
背景图片:url(image.png);
}

要更改任何SVG的颜色,您可以通过在任何文本编辑器中打开SVG文件来直接更改SVG代码。代码可能与下面的代码类似

<?xml version="1.0" encoding="utf-8"?>
    <!-- Generator: Adobe Illustrator 16.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
    <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
    <svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
         width="500px" height="500px" viewBox="0 0 500 500" enable-background="new 0 0 500 500" xml:space="preserve">
    <g>
        <path d="M114.26,436.584L99.023,483h301.953l-15.237-46.416H114.26z M161.629,474.404h-49.592l9.594-29.225h69.223
            C181.113,454.921,171.371,464.663,161.629,474.404z"/>
    /*Some more code goes on*/
    </g>
    </svg>

/*还有一些代码在继续*/
您可以看到有一些XML标记,如路径、圆、多边形等。在那里,您可以借助样式属性添加自己的颜色。看看下面的例子

<path style="fill:#AB7C94;" d="M114.26,436.584L99.023,483h301.953l-15.237-46.416H114.26z M161.629,474.404h-49.592l9.594-29.225h69.223
                C181.113,454.921,171.371,464.663,161.629,474.404z"/>


将style属性添加到所有标记中,以便获得所需颜色的SVG

要更改任何SVG的颜色,可以通过在任何文本编辑器中打开SVG文件直接更改SVG代码。代码可能与下面的代码类似

<?xml version="1.0" encoding="utf-8"?>
    <!-- Generator: Adobe Illustrator 16.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
    <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
    <svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
         width="500px" height="500px" viewBox="0 0 500 500" enable-background="new 0 0 500 500" xml:space="preserve">
    <g>
        <path d="M114.26,436.584L99.023,483h301.953l-15.237-46.416H114.26z M161.629,474.404h-49.592l9.594-29.225h69.223
            C181.113,454.921,171.371,464.663,161.629,474.404z"/>
    /*Some more code goes on*/
    </g>
    </svg>

/*还有一些代码在继续*/
您可以看到有一些XML标记,如路径、圆、多边形等。在那里,您可以借助样式属性添加自己的颜色。看看下面的例子

<path style="fill:#AB7C94;" d="M114.26,436.584L99.023,483h301.953l-15.237-46.416H114.26z M161.629,474.404h-49.592l9.594-29.225h69.223
                C181.113,454.921,171.371,464.663,161.629,474.404z"/>


将style属性添加到所有标记中,以便获得所需颜色的SVG

最简单的方法是使用类似的服务从SVG中创建字体。上传您的SVG,点击“生成字体”,将字体文件和css包含到您的页面中,只需像其他文本一样使用和设置样式即可。我总是这样使用它,因为它使造型更容易


编辑:正如@CodeMouse92评论中提到的图标字体会弄乱屏幕阅读器(可能对搜索引擎优化不利)。因此,还是坚持使用SVG吧。

最简单的方法是使用SVG之类的服务创建字体。上传您的SVG,点击“生成字体”,将字体文件和css包含到您的页面中,只需像其他文本一样使用和设置样式即可。我总是这样使用它,因为它使造型更容易


编辑:正如@CodeMouse92评论中提到的图标字体会弄乱屏幕阅读器(可能对搜索引擎优化不利)。因此,请坚持使用SVG。

如果使用一些技巧,可以使用css更改SVG的颜色。 我为此写了一个小剧本

  • 浏览包含svg图像的元素列表
  • 将svg文件作为xml加载
  • 仅获取svg部分
  • 更改路径的颜色
  • 将src替换为修改后的svg作为内联图像
$('img.svg可变')。每个(函数(){
var$e=$(本);
var imgURL=$e.prop('src');
$.get(imgURL,函数(数据){
//获取SVG标记,忽略其余部分
var$svg=$(数据).find('svg');
//换颜色
$svg.find('path').attr('fill','#000');
$e.prop('src',“数据:image/svg+xml;base64,”+window.btoa($svg.prop('outerHTML'));
});
});
上面的代码可能无法正常工作,我已经为带有svg背景图像的元素实现了这一点,其工作原理与此类似。
但无论如何,您必须修改此脚本以适合您的情况。希望对您有所帮助。

如果您使用一些技巧,可以使用css更改SVG的颜色。 我为此写了一个小剧本

  • 浏览包含svg图像的元素列表
  • 将svg文件作为xml加载
  • 仅获取svg部分
  • 更改路径的颜色
  • 将src替换为修改后的svg作为内联图像
$('img.svg可变')。每个(函数(){
var$e=$(本);
var imgURL=$e.prop('src');
$.get(imgURL,函数(数据){
//获取SVG标记,忽略其余部分
var$svg=$(数据).find('svg');
//换颜色
$svg.find('path').attr('fill','#000');
$e.prop('src',“数据:image/svg+xml;base64,”+window.btoa($svg.prop('outerHTML'));
});
});
上面的代码可能无法正常工作,我已经为带有svg背景图像的元素实现了这一点,其工作原理与此类似。
但无论如何,您必须修改此脚本以适合您的情况。希望有帮助。

添加了一个测试页面-通过过滤器设置为SVG着色:

例如
过滤器:反转(0.5)深褐色(1)饱和(5)色调旋转(175度)


这个想法来源于:

添加了一个测试页面,通过过滤器集将SVG转换为彩色
<path fill="#ccc">
svg{
   path{
        fill: #ccc
$("#struct1").css("fill","<desired colour>");
.cameraicon {
height: 1.6em;/* set your own icon size */
mask: url(/camera.svg); /* path to your image */
-webkit-mask: url(/camera.svg) no-repeat center;
}
<td class="text-center">
    <div class="bg-secondary cameraicon"/><!-- "bg-secondary" sets actual color of your icon -->
</td>
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="#bbb9c6">
<path d="M20 2H4c-1.1 0-1.99.9-1.99 2L2 22l4-4h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zm-2 12H6v-2h12v2zm0-3H6V9h12v2zm0-3H6V6h12v2z"/><path d="M0 0h24v24H0z" fill="none"/></svg>
@mixin icon($color, $hoverColor) {
    svg {
        fill: $color;

        circle, line, path {
            fill: $color
        }

        &:hover {
            fill: $hoverColor;

            circle, line, path {
                fill: $hoverColor;
            }
        }
    }
}
.container {
    @include icon(white, blue);
}
<svg version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" 
   xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
   viewBox="0 0 477.526 477.526" style="enable-background:new 0 0 477.526 477.526; 
   fill: rgb(109, 248, 248);" xml:space="preserve"> 
<svg />
<svg width="800" height="600" xmlns="http://www.w3.org/2000/svg">
      <g>
          <title>background</title>
          <rect fill="#fff" id="canvas_background" height="602" width="802" y="-1" 
           x="-1"/>
           <g display="none" overflow="visible" y="0" x="0" height="100%" width="100%" 
           id="canvasGrid">
              <rect fill="url(#gridpattern)" stroke-width="0" y="0" x="0" height="100%" 
              width="100%"/>
           </g>
       </g>
</svg>
.colorize-pink {
  filter: brightness(0.5) sepia(1) hue-rotate(-70deg) saturate(5);
}

.colorize-navy {
  filter: brightness(0.2) sepia(1) hue-rotate(180deg) saturate(5);
}

.colorize-blue {
  filter: brightness(0.5) sepia(1) hue-rotate(140deg) saturate(6);
}