【问题标题】:Add multiple instances of SVG node to DOM将 SVG 节点的多个实例添加到 DOM
【发布时间】:2018-07-13 04:29:25
【问题描述】:

我有一个 SVG 文件列表,所以我使用 SnapSVG 加载它们。 现在我想将每个 SVG 的多个实例随机添加到一个容器中,其中一些实例会重复。

问题是当我添加一个已经添加的时,第一个消失了。

    var objects; // pretend this is a list of objects which are SVG files loaded with SnapSVG.

    for (var i = 0; i < NUM_OBJECTS; i++) {
        let r = getRandomInteger(0, svgs.length - 1);

        container.appendChild( objects[r].node );
    }

这里,它从对象中抓取节点并将其附加到容器中:

container.appendChild( objects[r].node );

我假设对象仍然持有对节点的引用(因为它可以在以后的迭代中再次添加)。

但是如果我们再次抓取该节点并将其添加到 DOM 中,之前添加的节点就会消失,这让我认为它是该节点的唯一实例。

这有意义吗?如果是这样,有没有办法克隆 SVG 对象或类似的东西?

【问题讨论】:

    标签: javascript svg snap.svg


    【解决方案1】:

    一个 DOM 节点(无论是 HTML 还是 SVG)不能位于多个位置(任何节点都指向其父节点)。

    您必须使用cloneNode 克隆节点。

    【讨论】:

      猜你喜欢
      • 2016-07-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-01-10
      • 1970-01-01
      • 1970-01-01
      • 2013-05-05
      相关资源
      最近更新 更多