DOM操作提供六种核心技巧:一、createElement+appendChild添加元素;二、insertBefore精确插入;三、replaceChild替换节点;四、removeChild删除子元素;五、innerHTML/textContent批量更新;六、cloneNode复制结构。

如果您需要动态调整网页内容或响应用户交互,直接修改HTML文档结构是核心需求。DOM操作提供了多种方式来添加、删除、替换或移动页面元素。以下是实现这些目标的实用技巧:
一、使用createElement和appendChild添加新元素
该方法通过JavaScript创建新节点并追加到指定父元素末尾,适用于动态生成按钮、列表项等结构化内容。
1、调用document.createElement("div")创建一个空的div元素节点。
2、使用newElement.textContent = "欢迎访问"为该节点设置文本内容。
立即学习“前端免费学习笔记(深入)”;
3、获取目标容器元素:const container = document.getElementById("main");
4、执行container.appendChild(newElement)将新元素插入到容器末尾。
二、使用insertBefore在指定位置插入节点
当需将新元素插入到现有子元素之前时,insertBefore可精确控制插入点,避免依赖索引计算错误。
1、创建待插入的新节点:const newItem = document.createElement("li");
2、设置其innerHTML为"首页"。
3、获取父元素:const list = document.querySelector("ul");
4、获取参考子节点:const firstItem = list.firstElementChild;
5、执行list.insertBefore(newItem, firstItem)将新节点置于第一个子元素之前。
三、使用replaceChild替换现有节点
该方法允许用新节点完全替代旧节点,常用于更新模块内容或切换视图组件。
1、创建替换用的新节点:const replacement = document.createElement("section");
2、设置replacement.className = "updated-content";
3、获取被替换的目标节点:const oldNode = document.querySelector(".legacy-box");
4、获取其父节点:const parent = oldNode.parentNode;
5、执行parent.replaceChild(replacement, oldNode)完成替换操作。
四、使用removeChild删除指定子元素
该方法从DOM树中移除特定子节点,同时保留在内存中以便后续复用或检查属性。
1、获取要删除的节点:const target = document.getElementById("ad-banner");
2、确认该节点存在且有父节点:if (target && target.parentNode) {
3、调用target.parentNode.removeChild(target);
4、此时target仍可访问,但已脱离文档流。
五、使用innerHTML和textContent批量更新内容
对于纯内容替换场景,innerHTML支持HTML解析,textContent仅处理纯文本,二者性能与安全性表现不同。
1、更新整个容器HTML:document.getElementById("content").innerHTML = "
新段落加粗文字
";2、若仅需纯文本更新,使用textContent更安全:document.getElementById("title").textContent = "安全标题";
3、注意:innerHTML会销毁原有子节点绑定的事件监听器,而textContent不会触发重绘风险。
六、使用cloneNode复制节点结构
该方法可快速生成具有相同标签、属性及子节点的副本,适用于模板重复渲染场景。
1、获取原始节点:const template = document.querySelector(".card-template");
2、调用template.cloneNode(true)深拷贝整个结构(含子节点)。
3、修改副本中的文本内容:cloned.querySelector("h3").textContent = "新卡片标题";
4、将副本添加至目标区域:document.body.appendChild(cloned);
5、注意:cloneNode(false)仅复制当前节点,不包含子节点。











