DOM节点
什么是DOM
DOM,全称Document Object Model文档对象模型。
• JS中通过DOM来对HTML文档进行操作。只要理解了DOM就可以随
心所欲的操作WEB页面。
• 文档
– 文档表示的就是整个的HTML网页文档
• 对象
– 对象表示将网页中的每一个部分都转换为了一个对象。
• 模型
– 使用模型来表示对象之间的关系,这样方便我们获取对象
节点
• 节点Node,是构成我们网页的最基本的组成部分,网页中的
每一个部分都可以称为是一个节点。
• 比如:html标签、属性、文本、注释、整个文档等都是一个节
点。
• 虽然都是节点,但是实际上他们的具体类型是不同的。
• 比如:标签我们称为元素节点、属性称为属性节点、文本称为
文本节点、文档称为文档节点。
• 节点的类型不同,属性和方法也都不尽相同
节点
• 节点:Node——构成HTML文档最基本的单元。
• 常用节点分为四类
– 文档节点:整个HTML文档
– 元素节点:HTML文档中的HTML标签
– 属性节点:元素的属性
– 文本节点:HTML标签中的文本内容
文档节点(document)
• 文档节点document,代表的是整个HTML文
档,网页中的所有节点都是它的子节点。
• document对象作为window对象的属性存在
的,我们不用获取可以直接使用。
• 通过该对象我们可以在整个文档访问内查找节
点对象,并可以通过该对象创建各种节点对象
元素节点(Element)
• HTML中的各种标签都是元素节点,这也是我们最常用
的一个节点。
• 浏览器会将页面中所有的标签都转换为一个元素节点,
我们可以通过document的方法来获取元素节点。
• 比如:
– document.getElementById()
– 根据id属性值获取一个元素节点对象。
文本节点(Text)
• 文本节点表示的是HTML标签以外的文本内容,任意非HTML的文本
都是文本节点。
• 它包括可以字面解释的纯文本内容。
• 文本节点一般是作为元素节点的子节点存在的。
• 获取文本节点时,一般先要获取元素节点。在通过元素节点获取文本
节点。
• 例如:
– 元素节点.firstChild;
– 获取元素节点的第一个子节点,一般为文本节点
属性节点(Attr)
• 属性节点表示的是标签中的一个一个的属
性,这里要注意的是属性节点并非是元素
节点的子节点,而是元素节点的一部分。
• 可以通过元素节点来获取指定的属性节点。
• 例如:
– 元素节点.getAttributeNode("属性名");
• 注意:我们一般不使用属性节点
获取元素节点
• 通过document对象调用
-
getElementById()
– 通过id属性获取一个元素节点对象
-
getElementsByTagName()
– 通过标签名获取一组元素节点对象
-
getElementsByName()
– 通过name属性获取一组元素节点对象
获取元素节点
• 通过document对象调用
-
getElementById()
– 通过id属性获取一个元素节点对象
-
getElementsByTagName()
– 通过标签名获取一组元素节点对象
-
getElementsByName()
– 通过name属性获取一组元素节点对象
-
获取父节点和兄弟节点
• 通过具体的节点调用
-
parentNode
– 属性,表示当前节点的父节点
-
previousSibling
– 属性,表示当前节点的前一个兄弟节点
-
nextSibling
– 属性,表示当前节点的后一个兄弟节点
元素节点的属性
• 获取,元素对象.属性名
例:element.value
element.id
element.className
• 设置,元素对象.属性名=新的值
例:element.value = “hello”
element.id = “id01”
element.className = “newClass
元素节点的属性
• 获取,元素对象.属性名
例:element.value
element.id
element.className
• 设置,元素对象.属性名=新的值
例:element.value = “hello”
element.id = “id01”
element.className = “newClass
元素节点的属性
• 获取,元素对象.属性名
例:element.value
element.id
element.className
• 设置,元素对象.属性名=新的值
例:element.value = “hello”
element.id = “id01”
element.className = “newClass
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)