0

0

JavaScript中关于DOM的操作详解

黄舟

黄舟

发布时间:2017-08-13 10:33:24

|

1625人浏览过

|

来源于php中文网

原创

一、什么是dom

  JavaScript由ECMAScript、DOM和BOM三部分组成,其中DOM代表描述网页内容的方法和接口,即文档对象模型(Document Object Model)。在网页上,组织页面(或文档)的对象被组织在一个树形结构中,用来表示文档中对象的标准模型就称为DOM,而树形结构就是我们常说的DOM树。

  维基百科中介绍DOM更为准确:DOM是一种跨平台和语言非依赖性的应用程序编程接口,即处理现在的HTML,XHTML或XML文档作为树结构,其中每个节点是一个对象,每个节点表示该文档的一部分。

二、DOM节点

1.节点的类型

立即学习Java免费学习笔记(深入)”;

  DOM树是由许多不同类型的节点组成的,而这些节点类型都有一个nodeType值,我们可以通过nodeType值来判断我们获取的或想要的是不是对应类型的节点。

节点类型 元素节点(标签节点) 属性节点 文本节点(空格、换行、文字) 注释节点 document节点
nodeType值 1 2 3 8 9

  除了通过nodeType值判断类型以外我们还可以通过nodeName来查看元素节点和属性节点的节点名称,还有使用nadeValue来查看属性节点的属性值。

 

2.获取元素节点


document.getElementById(id);
document.getElementByTagName(tagname);
document.getElementByClassName(classname);

  通常想要在JavaScript中更改或使用HML中的元素节点时,都要先获取才可以调用,那么我们就是通过设置元素的Id属性或Class属性来获取,或是使用标签名获取。但是要注意的是getElementById()方法不能工作在XML中,在XML文档中,必须通过拥有id属性来进行搜索,而此类型必须在 XML DTD 中进行声明。

  获取完我们想要的节点后,我们还可以通过节点的关系来操作其他节点,这里我们以p元素为初设元素节点来举例。

  2.1 子节点


p.children();
p.childNodes();

 

  获取p下面的子节点,而p.children()只能获取到是元素节点的子节点,而p.childNodes()会获取所有类型的子节点,也就是说会解析空白文本节点。

  2.2 父节点


p.parentNode();
p.offsetParent();

 

  获取p的父节点,p.offsetParent()获取的是具有定位属性的祖先节点,即从父节点开始查找,如果父节点没有定位属性,那么再找父节点的父节点,直到找到有定位属性的节点。

  2.3 兄弟节点


//下一个兄弟节点 p.nextElementSibling();
p.nextSibling();//上一个兄弟节点 p.previousElementSibling();
p.previousSibling();

 

  这里有没有Element很关键,跟获取子节点一样,p.nextSibling()和p.previousSibling()会解析空白节点,会获取到p下面的空格或回车。

  2.4 首尾子节点


//获取p的第一个子节点p.firstElementChild();
p.firstChild();//获取p的最后一个子节点p.lastElementChild();
p.lastElementChild();

 

  区别同上。

Python精要参考 pdf版
Python精要参考 pdf版

这本书给出了一份关于python这门优美语言的精要的参考。作者通过一个完整而清晰的入门指引将你带入python的乐园,随后在语法、类型和对象、运算符与表达式、控制流函数与函数编程、类及面向对象编程、模块和包、输入输出、执行环境等多方面给出了详尽的讲解。如果你想加入 python的世界,David M beazley的这本书可不要错过哦。 (封面是最新英文版的,中文版貌似只译到第二版)

下载

 

3.节点操作

  我们除了可以在HTML中添加、删除个修改节点,也可以在JavaScript中对节点进行操作。

  3.1 创建节点


//创建节点/创建文本节点createElement();
createTextNode();

 

  创建文本节点一般用来向元素节点中添加内容,它创建的是静态文本,不能像innerHTML一样带有HTML格式,所以creatTextNode()更安全,而innerText又有浏览器兼容问题。

  3.2 添加节点

  我们创建的节点不会自动添加到HTML里,需要我们对创建的节点进行操作。


//向尾部添加子节点 appendChild(); 
//向目标节点之前添加insertBefore(newElement,targetElement);

  insertBefore()第二个参数是可选参数,如果不写第二个参数那么就默认向尾部添加,即等同于appendChild();

  3.3 替换


//将旧节点换为新节点replaceChild(newElement,oldElement);

  p.replaceChild(newElement,oldElement) ,这里无论是新节点还是旧节点,都必须是p的子节点。

  3.4 删除


removeChild();

  注意删除的是子节点。

  3.5 克隆/复制


//深复制或浅复制cloneNode(boolean);

  当参数的布尔值为true时为深复制,即会复制节点本身以及它以下的所有子节点。

  当参数的布尔值为false时为浅复制,只会复制节点自己本身。

  3.6 判断


hasChildNode();

  判断是否有子节点,返回布尔值。

  3.7 属性


//获取节点属性getAttribute();//设置节点属性setAttribute();//删除节点属性removeAttribute();

  要注意的一点就是class属性不能通过setAttribute(); 设置。

三、DOM的优缺点

  DOM的优点主要表现在:易用性强,并且遍历简单,支持XPath,增强了易用性。

  DOM的缺点主要表现在:效率低,解析速度慢,内存占用量过高。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

9

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

59

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

80

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

38

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

17

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

155

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

161

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.9万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号