今天,让我们来了解一下JS中的DOM文档对象模型吧!
一.首先,我们知道对象有三种,分别是内建对象、宿主对象和自定义对象。DOM对象和另一种对象(BOM对象模型)都属于宿主对象。
二.那么,什么是DOM对象模型?
DOM,全称Document Object Model文档对象模型,JS中通过DOM来对HTML文档进行操作。只要理解了DOM就可以随心所欲的操作WEB页面。
文档 ,文档表示的就是整个的HTML网页文档;
对象 ,对象表示将网页中的每一个部分都转换为了一个对象;
模型, 使用模型来表示对象之间的关系,这样方便我们获取对象;
三.HTML DOM树
html标签、属性、文本、注释、整个文档等都是一个节点。
四.节点(Node)
1.节点不仅是构成我们网页的最基本的组成部分,也是构成HTML文档最基本的单元。网页中的每一个部分都可以称为是一个节点。
2.虽然都是节点,但是实际上他们的具体类型是不同的。比如:标签我们称为元素节点、属性称为属性节点、文本称为文本节点、文档称为文档节点。节点的类型不同,属性和方法也都不尽相同。
3. 常用节点分为四类 :
文档节点:整个HTML文档;元素节点:HTML文档中的HTML标签;属性节点:元素的属性 ;文本节点:HTML标签中的文本内容。
⑴.文档节点(document):文档节点document,代表的是整个HTML文档,网页中的所有节点都是它的子节点;document对象作为window对象的属性存在的,我们不用获取可以直接使用;通过该对象我们可以在整个文档访问内查找节点对象,并可以通过该对象创建各种节点对象
⑵.元素节点(Element):HTML中的各种标签都是元素节点,这也是我们最常用的一个节点;浏览器会将页面中所有的标签都转换为一个元素节点,我们可以通过document的方法来获取元素节点。
如:document.getElementById();根据id属性值获取一个元素节点对象。
⑶.文本节点(Text):文本节点表示的是HTML标签以外的文本内容,任意非HTML的文本都是文本节点;它包括可以字面解释的纯文本内容;文本节点一般是作为元素节点的子节点存在的;获取文本节点时,一般先要获取元素节点。在通过元素节点获取文本节点
如:元素节点.firstChild;获取元素节点的第一个子节点,一般为文本节点。
⑷.属性节点(Attr):属性节点表示的是标签中的一个的属性,这里要注意的是属性节点并非是元素节点的子节点,而是元素节点的一部分;可以通过元素节点来获取指定的属性节点 (注意:我们一般不使用属性节点!)。
如:元素节点.getAttribute("属性名");
4.节点的属性:nodeName节点名称 nodeType 节点类型 nodeValue节点的值。