IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 文档对象模型DOM -> 正文阅读

[JavaScript知识库]文档对象模型DOM

定义

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个子字符串
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-07 10:43:35  更:2021-09-07 10:45:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 16:49:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码