news 2026/5/7 6:09:05

JavaScript DOM 原生部分(四):节点操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JavaScript DOM 原生部分(四):节点操作

文章目录

  • 一.节点的类型与基础概念
  • 二.创建节点
    • 1.创建元素节点( createElement )
    • 2.创建文本节点( createTextNode )
    • 3.创建文档片段( createDocumentFragment )
  • 三.添加节点
    • 1.追加子节点( appendChild )
    • 2.插入节点到指定位置( insertBefore )
    • 3.追加多个节点( append ,ES6+)
  • 四.删除节点
    • 1.删除子节点( removeChild )
    • 2.节点自删除( remove`,ES6+)
  • 五.替换节点
  • 六.复制节点(克隆节点)
  • 七.查找节点关系
  • 八.常用节点操作表
  • 注意事项
  • 总结

DOM 节点操作是 JavaScript 操作网页结构的核心,包括创建节点添加节点删除节点替换节点复制节点查找节点关系等.这些操作能动态修改网页的 DOM 树结构,实现页面的动态交互.

一.节点的类型与基础概念

DOM 节点主要分为几类:

  • 元素节点(如divpul):nodeType = 1
  • 属性节点(如classsrc):nodeType = 2
  • 文本节点(如元素内的文本):nodeType = 3
  • 注释节点:nodeType = 8

操作节点时,通常以元素节点为核心,以下示例均围绕元素节点展开.

二.创建节点

1.创建元素节点( createElement )

用于创建新的 HTML 元素,是最常用的创建节点方法.

// 创建一个 div 元素constnewDiv=document.createElement('div');// 为元素设置属性和内容newDiv.id='new-box';newDiv.className='content';newDiv.textContent='这是新创建的节点';

2.创建文本节点( createTextNode )

用于创建纯文本节点,可附加到元素节点中(也可直接用textContent/innerHTML替代).

// 创建文本节点consttextNode=document.createTextNode('Hello DOM');// 将文本节点添加到新创建的 div 中newDiv.appendChild(textNode);

3.创建文档片段( createDocumentFragment )

文档片段是轻量级的文档对象,用于批量添加节点,避免频繁操作 DOM 导致的性能损耗(仅需一次 DOM 重绘).

// 创建文档片段constfragment=document.createDocumentFragment();// 批量创建 li 节点并添加到片段中for(leti=0;i<5;i++){constli=document.createElement('li');li.textContent=`列表项${i+1}`;fragment.appendChild(li);}// 将片段一次性添加到 ul 中(片段本身不会被插入,仅插入其子节点)constul=document.querySelector('ul');ul.appendChild(fragment);

三.添加节点

将创建好的节点添加到 DOM 树中,常用方法有appendChildinsertBefore.

1.追加子节点( appendChild )

将节点添加到父节点的子节点列表的末尾.

// HTML:<div id="parent">父节点</div>constparent=document.getElementById('parent');// 创建子节点constchild=document.createElement('p');child.textContent='子节点';// 追加到父节点末尾parent.appendChild(child);// 结果:<div id="parent">父节点<p>子节点</p></div>

2.插入节点到指定位置( insertBefore )

将节点插入到父节点的某个子节点之前,语法:父节点.insertBefore(新节点, 参考节点).

// HTML:<div id="parent"><p id="old-child">旧子节点</p></div>constparent=document.getElementById('parent');constoldChild=document.getElementById('old-child');constnewChild=document.createElement('span');newChild.textContent='新子节点';// 将新节点插入到旧子节点之前parent.insertBefore(newChild,oldChild);// 结果:<div id="parent"><span>新子节点</span><p id="old-child">旧子节点</p></div>// 若参考节点为 null,则等同于 appendChildparent.insertBefore(newChild,null);

3.追加多个节点( append ,ES6+)

append是比appendChild更灵活的方法,支持同时添加多个节点或文本,且可添加字符串(自动转为文本节点).

parent.append(newChild,'直接添加文本',anotherChild);

四.删除节点

1.删除子节点( removeChild )

通过父节点删除子节点,语法:父节点.removeChild(子节点).

// HTML:<div id="parent"><p id="child">要删除的节点</p></div>constparent=document.getElementById('parent');constchild=document.getElementById('child');// 删除子节点parent.removeChild(child);// 若不确定父节点,可通过 node.parentNode 获取child.parentNode.removeChild(child);

2.节点自删除( remove`,ES6+)

更简洁的方法,节点可直接删除自身,无需通过父节点.

child.remove();// 直接删除当前节点

五.替换节点

使用replaceChild将父节点中的某个子节点替换为新节点.

语法:

父节点.replaceChild(新节点, 旧节点)
// HTML:<div id="parent"><p id="old-node">旧节点</p></div>constparent=document.getElementById('parent');constoldNode=document.getElementById('old-node');constnewNode=document.createElement('h3');newNode.textContent='新节点';// 替换节点parent.replaceChild(newNode,oldNode);// 结果:<div id="parent"><h3>新节点</h3></div>

六.复制节点(克隆节点)

使用cloneNode复制现有节点

语法:

节点.cloneNode(是否深克隆)
  • 浅克隆(false,默认):仅复制节点本身,不复制子节点和内容.
  • 深克隆(true):复制节点本身及所有子节点和内容.
// HTML:<div id="original"><p>原始内容</p></div>constoriginal=document.getElementById('original');// 浅克隆:仅复制 div 标签,不包含子节点constcloneShallow=original.cloneNode(false);console.log(cloneShallow);// <div id="original"></div>// 深克隆:复制 div 及内部的 p 节点constcloneDeep=original.cloneNode(true);cloneDeep.id='clone';// 避免 id 重复document.body.appendChild(cloneDeep);

七.查找节点关系

通过节点的属性获取其在 DOM 树中的关系节点,常用属性如下:

属性作用
parentNode获取当前节点的父元素节点(返回 null 表示无父节点)
children获取当前节点的所有子元素节点(HTMLCollection,仅元素节点)
childNodes获取当前节点的所有子节点(NodeList,包括文本、注释节点)
firstChild获取第一个子节点(包括文本节点)
firstElementChild获取第一个子元素节点(仅元素节点)
lastChild获取最后一个子节点(包括文本节点)
lastElementChild获取最后一个子元素节点(仅元素节点)
previousSibling获取上一个兄弟节点(包括文本节点)
previousElementSibling获取上一个兄弟元素节点(仅元素节点)
nextSibling获取下一个兄弟节点(包括文本节点)
nextElementSibling获取下一个兄弟元素节点(仅元素节点)
// HTML:<ul id="list"><li>项1</li><li id="item2">项2</li><li>项3</li></ul>constlist=document.getElementById('list');constitem2=document.getElementById('item2');console.log(item2.parentNode);// <ul id="list">(父节点)console.log(list.children);// HTMLCollection(3) [li, li#item2, li](子元素节点)console.log(item2.previousElementSibling);// <li>项1</li>(上一个兄弟元素)console.log(item2.nextElementSibling);// <li>项3</li>(下一个兄弟元素)

八.常用节点操作表

操作场景原生 JS 方法
创建元素节点document.createElement()
追加子节点parent.appendChild(child)
插入到指定位置parent.insertBefore(new, old)
删除节点child.remove()/parent.removeChild(child)
替换节点parent.replaceChild(new, old)
克隆节点node.cloneNode(true)
获取父节点node.parentNode
获取子元素节点node.children

注意事项

  1. 性能优化

    • 批量添加节点时,优先使用文档片段(DocumentFragment)批量操作,减少 DOM 重绘次数.
    • 避免在循环中直接操作 DOM,可先拼接节点或使用片段,最后一次性插入.
  2. 节点存在性检查

    • 操作节点前(如删除、替换),需检查节点是否存在,避免报错:
      constchild=document.getElementById('child');if(child){child.remove();}
  3. 克隆节点的 id 问题

    • 克隆节点时,若节点有唯一id,需修改克隆后的节点id,避免页面中 id 重复.
  4. 事件绑定的影响

    • 使用remove()删除节点时,原生事件(如addEventListener)会被移除.
  5. 文本节点的空白问题

    • childNodes会包含空白文本节点(如换行、空格),若只需获取元素节点,优先使用childrenfirstElementChild等属性.

总结

  • 原生 JavaScript 节点操作更底层、灵活,适合需要精细控制的场景,需熟悉节点关系和各类方法的语法.
  • 核心原则:减少不必要的 DOM 操作,批量操作优先使用文档片段,确保操作前节点存在,避免性能问题和报错.
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/2 21:43:41

从“监控”到“可观测”:2025年主流IT监控系统架构演进与选型建议

一、演进背景&#xff1a;从被动告警到主动观测的范式转移 1.传统监控的三重瓶颈 随着企业IT架构迈入“传统云原生国产化”混合时代&#xff0c;传统监控工具面临结构性挑战&#xff1a; •数据割裂&#xff1a;指标、日志、链路数据分散存储&#xff0c;故障定位需跨平台串联&…

作者头像 李华
网站建设 2026/5/1 7:42:14

如何在5分钟内完成Azure CLI量子作业结果导出?真相曝光

第一章&#xff1a;Azure CLI 量子作业结果导出的核心概念在使用 Azure Quantum 服务进行量子计算任务时&#xff0c;作业执行完成后获取并导出结果是关键步骤。Azure CLI 提供了一套命令行工具&#xff0c;用于提交量子作业、监控其状态以及提取计算结果。理解如何通过 Azure …

作者头像 李华
网站建设 2026/5/4 0:45:42

三相交流异步电动机保护器控制系统(论文+源码)

在本课题为三相交流异步电动机保护器控制系统设计&#xff0c;本文在结合实际需求的基础之上&#xff0c;将系统主要设计功能进行分析&#xff0c;主要如下&#xff1a;1.实现电机运行时的电压检测&#xff1b;2.实现电机运行时的电流检测&#xff1b;3.实现电机运行时的温度检…

作者头像 李华
网站建设 2026/5/6 21:01:25

基本运算放大器原理

★运算放大器电路图标&#xff1a;Vp&#xff1a;同相输入端 Vn&#xff1a;反向输入端 Vo&#xff1a;输出端 1.同相输入端与反向输入端的意义。同相位 Vp Vn Vo 上升 接地或稳定的电平 上升 下降 接地或稳定的电平 下降 反相位 Vp Vn Vo 上升 接地或稳定的电平 下降 下降 接地…

作者头像 李华
网站建设 2026/5/3 8:40:56

Utilizing 英文单词学习

1️、基本信息单词&#xff1a;utilizing词性&#xff1a;动词&#xff08;现在分词&#xff0c;动词原形 utilize&#xff09;发音&#xff1a; &#x1f1fa;&#x1f1f8; /ˈjuː.t̬əl.aɪzɪŋ/&#x1f1ec;&#x1f1e7; /ˈjuː.tɪ.laɪz.ɪŋ/词源&#xff1a; 来自…

作者头像 李华