JavaScript第十二讲:DOM编程“创建,删除,替换,插入节点”

目录

[1. 创建节点](#1. 创建节点)

[2. 删除节点](#2. 删除节点)

[3. 替换节点](#3. 替换节点)

[4. 插入节点](#4. 插入节点)

使用appendChild()

使用insertBefore()

深入解析与注意事项


1. 创建节点

在HTML DOM中,我们通常使用JavaScript的document.createElement()方法来创建元素节点,使用document.createTextNode()方法来创建文本节点。

示例代码

javascript 复制代码
// 创建一个新的<p>元素节点  
var newElement = document.createElement("p");  
  
// 创建一个文本节点  
var textNode = document.createTextNode("这是一个新的段落。");  
  
// 将文本节点添加到<p>元素节点中  
newElement.appendChild(textNode);  
  
// 将<p>元素节点添加到文档的body中  
document.body.appendChild(newElement);

2. 删除节点

要从DOM中删除一个节点,我们可以使用removeChild()方法。这个方法需要一个参数,即要删除的节点。

示例代码

javascript 复制代码
// 假设我们有一个id为"myElement"的元素要删除  
var elementToRemove = document.getElementById("myElement");  
  
// 获取其父元素  
var parentElement = elementToRemove.parentNode;  
  
// 从父元素中删除该元素  
parentElement.removeChild(elementToRemove);

3. 替换节点

在DOM中,我们通常不直接"替换"一个节点,而是先删除要替换的节点,然后在同一位置插入新的节点。但为了方便,我们可以将这两个步骤封装在一个函数中。

示例代码

javascript 复制代码
function replaceNode(oldNode, newNode) {  
    var parent = oldNode.parentNode;  
    if (parent) {  
        parent.replaceChild(newNode, oldNode);  
    }  
}  
  
// 创建一个新的<p>元素节点和文本节点  
var newElement = document.createElement("p");  
var newTextNode = document.createTextNode("这是替换后的段落。");  
newElement.appendChild(newTextNode);  
  
// 假设我们有一个id为"myElement"的元素要替换  
var oldElement = document.getElementById("myElement");  
  
// 调用函数替换节点  
replaceNode(oldElement, newElement);

4. 插入节点

在DOM中,插入节点通常涉及以下几个方法:

  • appendChild(): 将节点添加到父节点的子节点列表的末尾。
  • insertBefore(): 将节点插入到参考节点之前。

示例代码

使用appendChild()

javascript 复制代码
// 创建一个新的<p>元素节点和文本节点  
var newElement = document.createElement("p");  
var newTextNode = document.createTextNode("这是通过appendChild()添加的段落。");  
newElement.appendChild(newTextNode);  
  
// 将新元素添加到文档的body末尾  
document.body.appendChild(newElement);

使用insertBefore()

javascript 复制代码
// 假设我们有一个id为"referenceElement"的参考元素  
var referenceElement = document.getElementById("referenceElement");  
  
// 创建一个新的<p>元素节点和文本节点  
var newElement = document.createElement("p");  
var newTextNode = document.createTextNode("这是通过insertBefore()添加的段落,位于参考元素之前。");  
newElement.appendChild(newTextNode);  
  
// 将新元素插入到参考元素之前  
referenceElement.parentNode.insertBefore(newElement, referenceElement);

深入解析与注意事项

  • 在进行DOM操作时,要特别注意节点之间的关系,特别是父子关系和兄弟关系。
  • 在删除或替换节点之前,最好先检查该节点是否存在,以避免因尝试操作不存在的节点而引发错误。
  • 插入节点时,要注意插入的位置和参考节点的选择,以确保新节点被放置在正确的位置。
  • DOM操作可能会对页面的性能和用户体验产生影响,特别是在处理大量数据时。因此,在可能的情况下,应尽量减少不必要的DOM操作,或使用更高效的方法来更新页面内容。

希望今天的讲解对您有所帮助!终会与你重逢sj!

respect!

相关推荐
木卫二号Coding16 小时前
Docker-构建自己的Web-Linux系统-Ubuntu:22.04
linux·前端·docker
春日见16 小时前
win11 分屏设置
java·开发语言·驱动开发·docker·单例模式·计算机外设
2301_7800290416 小时前
支付宝sdk导入错误
java·开发语言·maven
CHU72903516 小时前
一番赏盲盒抽卡机小程序:解锁惊喜体验与社交乐趣的多元功能设计
前端·小程序·php
RFCEO16 小时前
前端编程 课程十二、:CSS 基础应用 Flex 布局
前端·css·flex 布局·css3原生自带的布局模块·flexible box·弹性盒布局·垂直居中困难
天若有情67316 小时前
XiangJsonCraft v1.2.0重大更新解读:本地配置优先+全量容错,JSON解耦开发体验再升级
前端·javascript·npm·json·xiangjsoncraft
2501_9445255417 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 预算详情页面
android·开发语言·前端·javascript·flutter·ecmascript
打小就很皮...17 小时前
《在 React/Vue 项目中引入 Supademo 实现交互式新手指引》
前端·supademo·新手指引
C澒17 小时前
系统初始化成功率下降排查实践
前端·安全·运维开发
17 小时前
java关于内部类
java·开发语言