8

所以我有一个带有一些预制渐变效果的 .svg 文件,如下所示:

<svg xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns="http://www.w3.org/2000/svg" height="1052.4" width="744.09" version="1.1" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" viewBox="0 0 670 680" style="width: 100%; height: 100%;">

<defs>
    <radialGradient id="grad1" cx="50%" cy="50%" r="50%" fx="50%" fy="50%">
        <stop offset="0%" style="stop-color: #a0a0a0;" />
        <stop offset="100%" style="stop-color: #a0a0a0;" />
    </radialGradient>
</defs>
 <g>
  <path id="path1" d="m124 263.35c6.4216-12.385 18.974-0.67157 0.72621z" fill="url(#grad1)">
  </path>
</g>
</svg>

这是我的 svg 文件的简化版本。它表示一个地图,其中每个状态都是一个路径元素。每个状态还具有与之关联的径向梯度标签。我遇到的问题是我在我的 HTML 文档中两次包含这个 SVG 文件,并且我更改了 svg 上的径向渐变标签,以分别更改每个地图上的状态颜色。

地图也有一些交互性,当用户将鼠标悬停在地图上时,我使用以下代码加载 svg 并添加将状态置于前面的事件(因此它的笔划是可见的):

$divSVG.load("map.svg", function() {
    $svg= $(this).find("svg");
    $svg.find("path").each(function() { 
        $(this).bind("mouseenter", function() {
                var $path= $(this);
            var $parent= $path.parent();
            //its necessary to detach and reattach the element so it comes to the front
            //of the image (there is no z-index in SVG)
            $path.detach();
            $parent.append($path);
            $path
                .css("stroke", "#FF0000")
                .css("stroke-width", "5px");
        });
        $(this).bind("mouseleave", function() {
            $(this)
                .css("stroke", "#FFFFFF")
                .css("stroke-width", "3px");
        });
    }
});

基本上我只是删除元素并在元素悬停时将其重新附加到其父级。

问题:当元素重新附加到文档中首先添加的地图上时,它开始使用第二个地图上存在的径向渐变。这意味着当我将第一张地图悬停时,状态会将颜色更改为与第二张地图相同的颜色。

我相信造成这种情况的原因是,由于它的同一个文件加载了两次,因此渐变 id 发生冲突,导致重新附加的元素从 HTML 文档中找到的最后一个渐变标记中获取其颜色,而不是其自己的 SVG 标记中存在的渐变标记。

所以这是我的问题,我该如何解决?我不想为每个具有唯一 ID 的地图创建一个新的 SVG 文件。我也不想通过 javascript 操作 id。有任何想法吗?

4

1 回答 1

8

SVG 注入器(如 Iconic SVGInjector或较新的 Iconfu SVGInject)通过在将 SVG 插入 HTML 文档时使 ID 唯一来解决此问题。Iconic 注入器在 ID 中添加了一个运行编号(grad1变成grad1-1),而 Iconfu 注入器添加了一个简短的随机字符串(grad1变成类似的东西grad1-4ew8ZeSw)。

不仅如果两个 SVG 使用相同的 ID,而且如果在 HTML 文档中多次使用相同的 SVG,则需要使 ID 唯一。

于 2018-09-11T06:34:42.803 回答