javascript - 使用 JQuery 更改 svg 内的填充颜色

标签 javascript jquery html css svg

我有一个嵌入“img src”标签内的 SVG 图像。 svg 包含带有颜色的不同路径,每个路径由 id 分隔。我想使用 jquery 更改每个 id 内的填充颜色

以下是我使用过的代码。但颜色没有改变。通过大量搜索,我发现如果直接将svg添加到html中,就可以了。一个工作示例:http://jsfiddle.net/P6t2B/

但是如果通过'img src'添加svg来实现它,我该如何实现呢?

html 内部:

<img src="images/hands.svg" width="70px"/>

JQuery 代码更改填充颜色 ID 'l1':

$('#l1').css({fill:"#000000"});

示例 SVG:

<path id="l1" fill="#ffffff" d="M85.6,227.3L85.6,227.3c14.2-5.7,21.1-22,15.3-36.2l-35.4-87.5c-2.5-6.1-9.5-9.1-15.6-6.6
    l-29.3,11.9c-6.1,2.5-9.1,9.5-6.6,15.6L49.4,212C55.1,226.1,71.4,233,85.6,227.3z"/>
<path id="l2" fill="#ffffff" d="M133.8,206.6L133.8,206.6c15.2-1.5,26.4-15.2,24.9-30.4L142.7,55.9
    c-0.6-6.6-6.5-11.4-13.1-10.8l-31.4,3.1c-6.6,0.6-11.4,6.5-10.8,13.1l16.1,120.3C104.9,196.9,118.6,208.1,133.8,206.6z"/>
<path id="l3" fill="#ffffff" d="M181.8,219.6L181.8,219.6c15,3,29.7-6.8,32.7-21.8l22.8-151.7c1.3-6.5-2.9-12.8-9.4-14.1
    l-31-6.2c-6.5-1.3-12.8,2.9-14.1,9.4L160,186.9C157,201.9,166.9,216.6,181.8,219.6z"/>
<path id="l4" fill="#ffffff" d="M227.8,247.1L227.8,247.1c13.9,6.5,30.5,0.4,37-13.4l58.1-142c2.8-6,0.2-13.2-5.8-16
    l-28.6-13.4c-6-2.8-13.2-0.2-16,5.8l-59.4,137.7C206.6,219.7,208.3,238,227.8,247.1z"/>
<path id="l5" fill="#ffffff" d="M257.1,245.1l51.8-41l37,0.5l24.5,15.4L337.7,256l-90.1,90.2l-31.6,15.9
    C216.1,362.1,184.1,325.9,257.1,245.1z"/>

最佳答案

这可能会起作用。

$('img.svg').each(function(){
    var $img = $(this);
    var imgClass = $img.attr('class');
    var imgURL = $img.attr('src');

    $.get(imgURL, function(data) {
        var $svg = $(data).find('svg');
        if(typeof imgClass !== 'undefined') {
            $svg = $svg.attr('class', imgClass+' style-color-black');
        }
        $svg = $svg.removeAttr('xmlns:a');
        $img.replaceWith($svg);
    }, 'xml');

});

来源:codedump

关于javascript - 使用 JQuery 更改 svg 内的填充颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40347307/

相关文章:

javascript - 如何与 Formdata 一起发送单个值

javascript - 如何动态更新输入值属性

javascript - 如何从单选按钮获取 jquery 或 JS 中的自定义属性值?

javascript - 如何将data-id发送到另一个页面

javascript - 提交时清除默认搜索文本

javascript - 社交媒体订阅/关注/喜欢链接不适用于动态添加的内容

javascript - Matter.js 创建一个旋转平台

javascript - 在当前 dom 之前添加 dom,并保持当前 dom 留在视口(viewport)中

javascript - Google Forms/Apps Script/Hangouts Chat - 机器人消息内容单独发送而不是一起发送

html - Angular - 选择选项元素上的单击事件