1
 function rearrange(x, y) {
    x.parentNode.replaceChild(x, y);
    x.parentNode.insertBefore(y,x); 
 }

如果我做

var a = document.getElementsByClassName('btn-button-google')[0];
var b = document.getElementsByClassName('btn-button-doodle')[0];
rearrange(b,a);

我收到以下错误

NotFoundError: Failed to execute 'replaceChild' on 'Node': The node to be replaced is not a child of this node.

我理解,因为 a 在一个 html div 中,而 b 在另一个 div 中,但我很好奇如何解决这个问题。这行得通

rearrange(b.parentNode,a.parentNode);

因为它们在同一个节点中。

示例 HTML

<div class="container">
   <div class="group">
     <a href="" class="btn-button-bold"><a>
     <a href="" class="btn-button-italic"><a>
     <a href="" class="btn-button-strike"><a>
   </div>
   <div class="group">
     <a href="" class="btn-button-font"><a>
     <a href="" class="btn-button-ffamily"><a>
     <a href="" class="btn-button-google"><a>
   </div>
   <div class="group">
      <a href="" class="btn-button-smilies"><a>
     <a href="" class="btn-button-doodle"><a>
     <a href="" class="btn-button-source"><a>
   </div>
</div>
4

1 回答 1

2

.replaceChild方法接受替换作为第一个参数,将要替换的孩子作为第二个参数。您将它们颠倒过来,这导致了错误。

此外,如果意图是交换,则需要保留对 的原始位置的引用y,因为一旦移动它,它就会被遗忘。

这适用于大多数情况:

var yPar = y.parentNode, ySib = y.nextSibling; 
x.parentNode.replaceChild(y, x); 
yPar.insertBefore(x, ySib);

请记住,还有一个问题需要考虑。只要两个节点有不同的父节点就没有问题,但是如果共享父节点,并且彼此相邻,并且缓存nextSibling与 相同x,则没有效果。因此,如果有可能,您需要对此进行测试,并处理这种特殊情况。

于 2014-07-16T17:37:23.643 回答