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