DOM 节点的克隆和导入

简介: 在使用 JS 操作 DOM 节点的时候,我们常常会用到克隆(或导入)节点的操作,那到底有哪些方法可以实现节点克隆(或导入)的效果呢?

17.png


前言


在使用 JS 操作 DOM 节点的时候,我们常常会用到克隆(或导入)节点的操作,那到底有哪些方法可以实现节点克隆(或导入)的效果呢?


今天,我们就来总结一下能实现节点克隆(或导入)效果的方法。


node.cloneNode()


提到克隆节点,我们最先能想到的肯定是 node.cloneNode() 方法。


语法


其语法如下:


let cloneNode = targetNode.cloneNode(deep);


  • cloneNode  最终克隆生成的节点副本。
  • targetNode   将要被克隆的目标节点。
  • deep   可选参数,表示是否需要进行深度克隆,即是否需要克隆 targetNode 下的子节点,默认为 false。


举例:


<body>
    <div id="container">
        <div class="header">这是头部</div>
        <div class="body">
            <div class="content">内容一</div>
            <div class="content">内容二</div>
        </div>
    </div>
    <script>
        const target = document.querySelector(".body");
        const cloneNode1 = target.cloneNode();
        console.log("cloneNode1.outerHTML\n\n",cloneNode1.outerHTML);
        const cloneNode2 = target.cloneNode(true);
        console.log("cloneNode2.outerHTML\n\n", cloneNode2.outerHTML);
    </script>
</body>


运行结果如下:


15.png


document.importNode()


将外部文档的一个节点拷贝一份,然后可以把这个拷贝的节点插入到当前文档中。语法如下:


let node = document.importNode(externalNode, deep);


  • node 从外部导入到当前文档的节点对象。
  • externalNode 外部文档中将要被导入的目标节点。
  • deep 是否深拷贝,默认为 false。


举例:


<!--iframe.html-->
<body>
    <h1>这是 Iframe 页面</h1>
    <div id="container">
        <div class="header">这是 Iframe 内容头部</div>
        <div class="body">这是 Iframe 内容主体</div>
    </div>
</body>
<!--index.html-->
<body>
    <div id="container">
        <div class="header">内容头部</div>
        <div class="body">内容主体</div>
    </div>
    <iframe id="iframe_ele" src="./iframe.html"></iframe>
    <script>
        window.onload = function () {
            const iframeEle = document.getElementById('iframe_ele');
            const iframeContainer = iframeEle.contentDocument.getElementById("container");
            const importedNode = document.importNode(iframeContainer, true);
            document.body.appendChild(importedNode);
        }
    </script>
</body>


最终效果如下:


14.png


document.adoptNode()


从其他的document文档中获取一个节点。 该节点以及它的子树上的所有节点都会从原文档删除 (如果有这个节点的话), 并且它的ownerDocument 属性会变成当前的document文档。 之后你可以把这个节点插入到当前文档中。语法:


let node = document.adoptNode(externalNode);
  • node 从外部文档中获取到的节点对象。
  • externalNode 将要被导入的外部文档中的节点对象。


举例:


<!--iframe.html-->
<body>
    <h1>这是 Iframe 页面</h1>
    <div id="container">
        <div class="header">这是 Iframe 内容头部</div>
        <div class="body">这是 Iframe 内容主体</div>
    </div>
</body>
<!--index.html-->
<body>
    <div id="container">
        <div class="header">内容头部</div>
        <div class="body">内容主体</div>
    </div>
    <iframe id="iframe_ele" src="./iframe.html"></iframe>
    <script>
        window.onload = function () {
            const iframeEle = document.getElementById('iframe_ele');
            const iframeContainer = iframeEle.contentDocument.getElementById("container");
            const node = document.adoptNode(iframeContainer);
            document.body.appendChild(node);
        }
    </script>
</body>


效果:


13.png


总结


以上就是使用 JS 克隆(或导入)DOM 节点的方法总结。


~ 本文完,感谢阅读!


学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!




相关文章
|
1天前
|
XML JavaScript 数据格式
XML DOM 遍历节点树
在处理XML文档时,我们常需提取各元素值,这时就要用到XML DOM的节点树遍历功能。以下示例展示了如何遍历根元素的所有子节点,并输出它们的名称和值:例如 &quot;title: Everyday Italian&quot;,&quot;author: Giada De Laurentiis&quot; 等。
|
1天前
|
存储 JavaScript
DOM 节点列表长度(Node List Length)
名为 &quot;title&quot; 的元素节点,并存储在节点列表 x 中。通过 &quot;length&quot; 属性确定 x 的长度(即 &quot;title&quot; 节点总数)。利用 for 循环遍历整个列表,访问每个 &quot;title&quot; 节点的第一个子节点的值,并将其写入文档。
|
7天前
|
XML JavaScript 数据格式
XML DOM 遍历节点树
在处理XML文档时,我们常需提取各元素值,这时就要用到XML DOM的节点树遍历功能。以下示例展示了如何遍历根元素的所有子节点,并输出它们的名称和值:例如 &quot;title: Everyday Italian&quot;,&quot;author: Giada De Laurentiis&quot; 和 &quot;year: 2005&quot;。实现步骤包括:加载XML字符串到xmlDoc对象,获取根元素子节点,然后遍历并输出每个子节点的信息。
|
9天前
|
XML JavaScript 数据格式
XML DOM 遍历节点树
在处理XML文档时,我们常需提取各元素值,这时就要用到XML DOM的节点树遍历功能。以下示例展示了如何遍历根元素的所有子节点,并输出它们的名称和值:例如 &quot;title: Everyday Italian&quot;,&quot;author: Giada De Laurentiis&quot; 和 &quot;year: 2005&quot;。此例首先将XML字符串加载至xmlDoc中,接着获取根元素的子节点,并逐一输出每个子节点的信息。
|
9天前
|
存储 JavaScript
DOM 节点列表长度(Node List Length)
名为 &quot;title&quot; 的元素节点,并存储在节点列表 x 中。通过循环遍历节点列表,利用 length 属性确定列表中的节点数量,并依次访问每个节点的 childNodes[0](即节点内的文本内容),将其输出到文档中。
|
11天前
|
XML JavaScript 数据格式
XML DOM 遍历节点树
在处理XML文档时,我们常需提取各元素值,这时就要用到XML DOM的节点树遍历功能。以下示例展示了如何遍历根元素的所有子节点,并输出它们的名称和值:例如 &quot;title: Everyday Italian&quot;,&quot;author: Giada De Laurentiis&quot; 和 &quot;year: 2005&quot;。实现步骤包括:加载XML字符串到xmlDoc对象,获取根元素子节点,最后输出每个子节点的名称与文本节点的值。
|
11天前
|
存储 JavaScript
DOM 节点列表长度(Node List Length)
名为 &quot;title&quot; 的元素节点,并存储在节点列表 x 中。通过 &quot;length&quot; 属性确定 x 的长度(即 &quot;title&quot; 节点总数)。利用 for 循环遍历整个列表,访问每个 &quot;title&quot; 节点的第一个子节点的值,并将其写入文档。
|
14天前
|
XML JavaScript 数据格式
XML DOM 遍历节点树
在处理XML文档时,我们常需提取各元素值,这时就要用到XML DOM的节点树遍历功能。以下示例展示了如何遍历根元素的所有子节点,并输出它们的名称和值:例如 &quot;title: Everyday Italian&quot;,&quot;author: Giada De Laurentiis&quot; 等。首先将XML字符串加载至xmlDoc,然后获取根元素的子节点列表并输出每个子节点的信息。
|
13天前
|
XML JavaScript 数据格式
XML DOM 遍历节点树
在处理XML文档时,我们常需提取各元素值,这时就要用到XML DOM的节点树遍历功能。以下示例展示了如何遍历根元素的所有子节点,并输出它们的名称和值:例如 &quot;title: Everyday Italian&quot;,&quot;author: Giada De Laurentiis&quot; 等。
|
18天前
|
XML 存储 JavaScript
XML DOM - 访问节点
XML DOM 允许你访问XML文档中的每一个节点。你可以通过三种方式进行节点访问:使用 `getElementsByTagName()` 方法、循环遍历节点树或通过节点间的关系进行导航。`getElementsByTagName()` 返回一个节点列表,即节点的数组形式。示例代码展示了如何将 &quot;books.xml&quot; 文件加载到 `xmlDoc` 中,并随后在变量 `x` 中存储这些信息。