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

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

时间:2024-06-24 12:28:10浏览次数:35  
标签:appendChild 编程 DOM JavaScript newElement var 元素 document 节点

目录

1. 创建节点

2. 删除节点

3. 替换节点

4. 插入节点

使用appendChild()

使用insertBefore()

深入解析与注意事项


1. 创建节点

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

示例代码

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

2. 删除节点

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

示例代码

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

3. 替换节点

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

示例代码

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()

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

使用insertBefore()

// 假设我们有一个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!

标签:appendChild,编程,DOM,JavaScript,newElement,var,元素,document,节点
From: https://blog.csdn.net/2303_80856850/article/details/139922095

相关文章

  • 实验7 文件应用编程
    4.实验任务4:1#include<stdio.h>23intmain()4{5inti=0;6FILE*fp;7charstr[100];8charch;910fp=fopen("data4.txt","r");11if(fp==NULL)12{13printf("failt......
  • 华为在 2024 年 6 月 21 日的华为开发者大会上,华为终端 BG 软件部总裁龚体正式官宣了
    华为在2024年6月21日的华为开发者大会上,华为终端BG软件部总裁龚体正式官宣了华为自研仓颉编程语言,并发布了HarmonyOSNEXT仓颉语言开发者预览版。仓颉编程语言文件后缀名为.cj,以下是第一个入门代码输出:你好,仓颉。仓颉编程语言的名字来自“仓颉造字”。仓......
  • 未来十年最受欢迎的编程语言
    学习编程最困难的地方是,如果你是软件开发领域的新手,那么最难的是弄清楚哪种是最好的编程语言。有许多编程语言,每种都有独特的特点和复杂性。好消息是,当您的软件开发项目启动时,您将开始了解哪种编程语言最适合您的需求、兴趣和职业目标。未来前10种编程语言将涵盖各种典......
  • java 并发编程面试(1)
    一、单例模式的DCL为啥要加volatile?避免指令重排,获取到未初始化完成的对象。单例模式的懒汉模式确保线程安全的机制DCLpublicclassMyTest{privatestaticMyTestmyTest;publicstaticMyTestgetInstance(){if(myTest==null){//check......
  • 颠覆传统编程,用ChatGPT十倍提升生产力
    我们即将见证一个新的时代!这是最好的时代,也是最坏的时代!需求背景背景:平时会编写博客,并且会把这个博客上传到github上,然后自己买一个域名挂到github上。我平时编写的博客会有一些图片来辅助说明的,写完之后如果我把图片和文字全部都上传到博客网站,后期图片很多时就会导致网......
  • How to get all subarrays from an array by using JavaScript All In One
    HowtogetallsubarraysfromanarraybyusingJavaScriptAllInOneJavaScript动态生成其所有的子数组算法difficulty:Medium/难度:中等solutionsdemos//双指针???//functionnumberOfSubarrays(nums:number[],k:number):number{//letcount=0......
  • 【JavaSE】(二)命令行/jdk编程
    jdkJavaDevelopmentKit(JDK)是一种用于开发Java应用程序的软件开发环境。它包括了Java运行时环境(JavaRuntimeEnvironment,JRE),以及一系列Java工具和Java基础类库。JDK(Java开发工具包)的组成JRE:Java的运行环境JVM:Java虚拟机,真正运行Java程序的地方。核心类库:Java自......
  • react-router-dom 6.4版本的尝鲜和总结
    1.版本概述1.1版本发布背景ReactRouter6.4版本是继6.0大版本更新之后的又一重要里程碑。此版本发布于2024年,旨在进一步优化开发者体验,提供更加强大和灵活的路由功能。6.4版本在前一版本的基础上,引入了新的数据抽象,增强了导航钩子,使得UI与数据的同步更加容易。1.2主......
  • python基础 - socket编程基础
    一对一---服务端importsocketip_port=('127.0.0.1',9999)1-创建socket对象---socket也叫套接字sk=socket.socket()2-绑定ip端口sk.bind(ip_port)3-开启监听sk.listen()print('---socket服务器已经启动完成---')4-阻塞等待客户端来链接可以返回连接对象......
  • 实验7_文件应用编程
    实验任务4#include<stdio.h>intmain(){FILE*fp;charch;intcount=0;fp=fopen("d:\\data4.txt","r");if(fp==NULL){printf("failtoopenfile\n");return0;}while(!feof(fp)){......