“Couper et Coller” - déplacement de nœuds dans les DOM avec Javascript

J'ai un code html qui ressemble à peu près comme ceci:

<div id="id1">
  <div id="id2">
    <p>some html</p>
    <span>maybe some more</span>
  </div>
  <div id="id3">
    <p>different text here</p>
    <input type="text">
    <span>maybe even a form item</span>
  </div>
</div>

Évidemment il n'y a plus que ça, mais c'est l'idée de base. Ce dont j'ai besoin pour faire est de modifier l'emplacement de stockage de #id2 et #id3, de sorte que le résultat est:

<div id="id1">
  <div id="id3">...</div>
  <div id="id2">...</div>
</div>

Personne ne sait d'une fonction (je suis sûr que je ne suis pas la première personne à besoin de cette fonctionnalité) qui peut lire et écrire les deux nœuds (et leurs enfants), de façon à troquer leur emplacement dans les DOM?

InformationsquelleAutor user41435 | 2008-11-27