How can I insert a DIV *between* an existing parent and child?

半世苍凉 提交于 2019-12-02 06:54:18

问题


Suppose I have a partial dom tree with a parent node and a set of children.

How can I interject a DIV between them?

I am starting with

parent --+--> child[0]
         |--> child[1]
         |--> child[2]

..and I want to end with

parent ---> newdiv ---+--> child[0]
                      |--> child[1]
                      |--> child[2]

How can I do this?

I need the converse of replaceChild() . Is there something like replaceParent() ?

I suppose I could clone all the child nodes, and then insert them as children in the new node. but... does that retain all the element ids?


EDIT - I didn't tag this with jQuery, or any framework, but maybe I should have been explicit about it. This is not a jQuery question. I want to do this in javascript + DHTML. No extra or outside framework.


回答1:


You can just move elements around by appending them to a new parent. In plain javascript:

var newDiv = document.createElement("div");

while(parent.hasChildNodes())
    newDiv.appendChild(parent.firstChild);

parent.appendChild(newDiv);

From the documentation of W3C about appendChild:

Adds the node newChild to the end of the list of children of this node. If the newChild is already in the tree, it is first removed.




回答2:


$('.child').wrapAll('<div class="newdiv"></div>');

More info: http://api.jquery.com/wrapAll/



来源:https://stackoverflow.com/questions/7700140/how-can-i-insert-a-div-between-an-existing-parent-and-child

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!