定义
DOM全称为“文档对象模型”(Document Object Model),DOM是针对HTML和XML文档的一个API(Application programming interfaces–应用程序编程接口),DOM描绘了一个层次化的节点树,允许开发人员添加,移除,修改页面的某一部分。
• 文档
– 文档表示的就是整个的HTML网页文档
• 对象
– 对象表示将网页中的每一个部分都转换为了一个对象。
• 模型
– 使用模型来表示对象之间的关系,这样方便我们获取对象
节点层级
任何 HTML 或 XML 文档都可以用 DOM 表示为一个由节点构成的层级结构。
DOM的最小组成单位叫做节点(node)。
节点的类型有七种:Document、DocumentType、Element、Text、Comment、DocumentFragment。
文档节点(document)——整个HTML文档document对象作为window对象的属性存在的,我们不用获取可以直接使用。
元素节点(Element)——HTML文档中的HTML标签。
属性节点(Attribute) ——元素的属性,表示的是标签中的一个一个的属性,这里要注意的是属性节点并非是元素节点的子节点,而是元素节点的一部分。
文本节点(Text)——HTML标签中的文本内容。
DocumentType——doctype标签节点(比如<!DOCTYPE html>
)。
Comment——注释节点
DocumentFragment——文档的片段节点
Node类型
DOM1级定义为一个Node接口,该接口将由DOM中的所有节点类型实现。javascript中所有的节点类型都继承自Node类型,所有节点类型都共享着相同的基本属性和方法。
Node 类型的属性和方法
属性
nodeType:nodeType属性返回一个整数值,表示节点的类型。文档节点(document)——9,元素节点(element)——1,属性节点(attr)——2,文本节点(text)——3,文档类型节点(DocumentType)——10,注释节点(Comment)——8,文档片断节点(DocumentFragment)——11。
nodeName:nodeName属性返回节点的名称。
nodeValue:nodeValue属性返回一个字符串,表示当前节点本身的文本值,该属性可读写只有文本节点(text)、注释节点(comment)和属性节点(attr)有文本值。
textContent:textContent属性返回当前节点和它的所有后代节点的文本内容。
nextSibling:nextSibling属性返回紧跟在当前节点后面的第一个同级节点。 当前节点后面没有同级节点,则返回null。
previousSibling:previousSibling属性返回当前节点前面的、距离最近的一个同级节点。如果当前节点前面没有同级节点,则返回null。
parentNode:parentNode属性返回当前节点的父节点。对于一个节点来说,它的父节点只可能是三种类型:元素节点(element)、文档节点(document)和文档片段节点(documentfragment)。
parentElement:parentElement属性返回当前节点的父元素节点。如果当前节点没有父节点,或者父节点类型不是元素节点,则返回null。
firstChild:firstChild属性返回当前节点的第一个子节点。
lastChild:lastChild属性返回当前节点的最后一个子节点。
childNodes:childNodes属性返回一个类似数组的对象(NodeList集合),成员包括当前节点的所有子节点。
方法
appendChild():appendChild方法接受一个节点对象作为参数,将其作为最后一个子节点,插入当前节点。该方法的返回值就是插入文档的子节点。
insertBefore():insertBefore方法用于将某个节点插入父节点内部的指定位置。第一个参数要插入的节点,第二个参数参照节点
removeChild():removeChild方法接受一个子节点作为参数,用于从当前节点移除该子节点。返回值是移除的子节点。
replaceChild():replaceChild方法用于将一个新的节点,替换当前节点的某一个子节点。第一个参数:要插入的节点;第二个参数:要替换的节点;第二个节点被删除。
cloneNode() :cloneNode() 方法用于复制节点无参数代表浅复制,有参数true代表深复制。浅复制只复制节点,不复制内容。深复制复制节点和内容。
innerHTML(): innerHTML()方法用于设别HTML代码片段。
innerText():innerText()方法用于只识别文本 去除空格和回车。
textContent():textContent()方法用于只识别文本,不去除空格和回车。
Document类型
Javascript通过使用Document类型表示文档。在浏览器中,document对象是HTMLDocument的一个实例,表示整个HTML页面。document对象是window对象的一个属性,因此可以直接调用。HTMLDocument继承自Document。
属性
documentElement:始终指向HTML页面中的元素。
body:直接指向元素。
doctype :访问<!DOCTYPE>, 浏览器支持不一致,很少使用。
title:获取文档的标题。
URL:取得完整的URL。
domain:取得域名,并且可以进行设置,在跨域访问中经常会用到。
referrer:取得链接到当前页面的那个页面的URL,即来源页面的URL。
images:获取所有的img对象,返回HTMLCollection类数组对象。
forms:获取所有的form对象,返回HTMLCollection类数组对象。
links:获取文档中所有带href属性的<a>
元素。
方法
方法 | 描述 |
---|---|
document.getElementById(id) | 通过元素 id 来查找元素 |
document.getElementsByTagName(name) | 通过标签名来查找元素 |
document.getElementsByClassName(name) | 通过类名来查找元素 |
document.querySelector() | 返回文档中匹配指定的CSS选择器的第一元素 |
document.querySelectorAll() | document.querySelectorAll() 是 HTML5中引入的新方法,返回文档中匹配的CSS选择器的所有元素节点列表 |
document.createElement(element) | 创建一个新的HTML元素,要与appendChild() 或 insertBefore()方法联合使用。 |
document.write() | 向文档写如文本或 HTML 表达式 或 JavaScript 代码。 |
Element类型
属性
属性 | 描述 |
---|---|
attributes | 返回一个与该元素相关的所有属性的集合。 |
classList | 返回该元素包含的 class 属性的集合。 |
className | 获取或设置指定元素的 class 属性的值。 |
clientHeight | 获取元素内部的高度,包含内边距,但不包括水平滚动条、边框和外边距。 |
clientTop | 返回该元素距离它上边界的高度。 |
clientLeft | 返回该元素距离它左边界的宽度。 |
clientWidth | 返回该元素它内部的宽度,包括内边距,但不包括垂直滚动条、边框和外边距。 |
innerHTML | 设置或获取 HTML 语法表示的元素的后代。 |
tagName | 返回当前元素的标签名。 |
方法
方法 | 描述 |
---|---|
element.innerHTML = new html content | 改变元素的 innerHTML |
element.attribute = value | 修改属性的值 |
element.getAttribute() | 返回元素节点的指定属性值。 |
element.setAttribute(attribute, value) | 设置或改变 HTML 元素的属性值 |
element.style.property = new style | 改变 HTML 元素的样式 |
Text类型
属性及方法
属性或方法 | 描述 |
---|---|
length | 文本长度 |
appendData(text) | 追加文本,text要追加的文本 |
deleteData(beginIndex,count) | 删除文本,beginIndex开始的位置,count要删除的字符数量 |
insertData(beginIndex,text) | 插入文本,beginIndex开始的位置,count要插入的字符数量 |
replaceData(beginIndex,count,text) | 替换文本,beginIndex开始的位置,count要替换的字符数量,text要替换的文本 |
splitText(beginIndex) | 从beginIndex位置将当前文本节点分成两个文本节点 |
document.createTextNode(text) | 创建文本节点,参数为要插入节点中的文本 |
substringData(beginIndex,count) | 从beginIndex开始提取count个子字符串 |