DOM讲解
创作时间:
作者:
@小白创作中心
DOM讲解
引用
CSDN
1.
https://blog.csdn.net/weixin_63698171/article/details/144589157
DOM(Document Object Model,文档对象模型)是连接网页和脚本(JavaScript、TypeScript)的桥梁。
1.DOM 的基本概念
DOM 将网页的结构表示为一个树形结构,其中每个元素、属性和文本都被表示为树中的一个节点。
- 文档节点(Document Node):树的根节点,代表整个HTML文档。
- 元素节点(Element Node):代表HTML元素,例如
<div>、<p>、<a>等。 - 属性节点(Attribute Node):代表HTML元素的属性,例如
id、class、href等。 - 文本节点(Text Node):代表HTML元素中的文本内容。
<!DOCTYPE html>
<html>
<head>
<title>DOM讲解</title>
</head>
<body>
<h1>欢迎</h1>
<p id="my-paragraph">这是一个段落。</p>
</body>
</html>
以上HTML在DOM中会被表示成类似这样的树状结构:
文档节点 (Document)
└── <html> 元素节点
├── <head> 元素节点
│ └── <title> 元素节点
│ └── 文本节点 ("DOM讲解")
└── <body> 元素节点
├── <h1> 元素节点
│ └── 文本节点 ("欢迎")
└── <p> 元素节点 (id="my-paragraph")
└── 文本节点 ("这是一个段落。")
2.DOM有什么用?
DOM的主要作用是允许JavaScript动态地访问和修改网页的内容、结构和样式。通过DOM,你可以:
- 访问HTML元素:通过ID、类名、标签名等方式获取页面上的元素。例如,使用
document.getElementById("my-paragraph")可以获取上面例子中的<p>元素。 - 修改HTML内容:改变元素的文本内容、HTML结构等。例如,使用
element.innerHTML = "新的内容"可以改变元素的内部HTML。 - 修改HTML样式:改变元素的CSS样式。例如,使用
element.style.color = "red"可以将元素的文本颜色改为红色。 - 添加或删除HTML元素:动态地向页面添加或删除元素。
- 响应事件:监听用户的操作(例如点击、鼠标悬停等),并执行相应的JavaScript代码。
3.DOM是怎么做到的?
DOM 树与浏览器渲染
当浏览器加载一个 HTML 页面时,它首先将 HTML 代码解析成DOM 树。DOM 树是一个树形结构,它把 HTML 元素(如<html>、<body>、<div>、<h1>等)表示为节点,这些节点之间通过父子关系连接。
DOM 树并不是直接呈现给用户看的,它是浏览器内部的一种数据结构,代表了页面的内容和结构。浏览器会根据 DOM 树来渲染页面内容并显示在用户的屏幕上。
通过修改 DOM 实现动态更新
一旦浏览器构建了 DOM 树,开发者可以通过 JavaScript 来操作 DOM,从而实现动态更新页面内容。
当我们修改 DOM 时,实际上是对 DOM 树进行修改。这些修改会立即反映到浏览器的页面上,达到动态更新HTML 内容的效果。
比如:
- 修改文本内容:可以通过 DOM 修改某个节点的文本内容。
- 修改样式:通过 DOM 修改节点的 CSS 样式。
- 添加/删除元素:可以通过 DOM 动态地插入或删除页面上的元素。
- 响应用户事件:当用户点击按钮、输入文本等,DOM 会响应这些事件并做出相应的改变。
修改 DOM 会更新页面的核心
- DOM 树是浏览器渲染页面的基础:浏览器通过 DOM 树来构建页面的内容和结构。因此,当你修改 DOM 树中的某个节点时,浏览器会重新渲染(或部分更新)页面,确保页面反映出最新的 DOM 结构。
- 浏览器实时响应:当你通过 JavaScript 修改 DOM 时,浏览器会实时更新页面显示,体现出动态效果。
总结
- DOM 树是浏览器用来表示页面内容的树形结构,它是浏览器渲染页面的基础。
- 通过 JavaScript 修改 DOM,你可以动态地更新页面内容,比如改变文本、样式,甚至添加或删除元素。
- 动态更新是指在不重新加载整个页面的情况下,通过修改 DOM 来改变页面内容和结构,这使得现代网页可以响应用户交互,提供丰富的动态效果。
热门推荐
南京大学VS北京大学:综合实力与专业优势全面对比
行测判断推理备考:类比推理中的复合考法怎么解答?
银行转账转错了能找回来吗
现代农业技术专业的求职者怎么写专业技能
高温天如何防暑降温?丨健康总动员
以人物成长挖掘故事深度,新版《上甘岭》“新”在哪儿
怎么检测瓷砖的质量好坏?这种检测方式有哪些要点?
崇祯,难道真的没办法拯救明朝危局了吗?
专科毕业论文写作指导及格式规范
查询开房记录需要哪些法律依据
USB口出问题?这样检查它的工作状态!
珠海:从无到有打造广东高等教育新高地
如何知道名字的含义(如何知道名字的含义和来历)
人工智能在交通领域的应用:自动驾驶与智能交通的未来
珍惜粮食 不负“好食光”
中国天眼探索宇宙深处,137亿光年外可疑信号:外星人存在之谜待解
十五夜望月王建原文及翻译注释赏析
中国各省简称大全:快速掌握省份代号,轻松了解中国地理
盆栽千年木如何养护?这里有详细的养殖方法和注意事项
智能化无人装备发展现状及趋势研究
孩子到底能不能打?这个答案出乎意料
面试官亲口告诉你:线上vs线下面试,哪个更容易拿offer?
NPD自恋型人格障碍:成因、症状与治疗方案
多板块投资分析与市场态势洞察
高企认定中的研发费用占比率深度解析
FIFA足球世界手游球员数据库详解:动态更新机制与实战应用
国粹麻将:各地规则大不同,揭示丰富地方文化
有一种治愈,由可爱的狗狗带来
如何通过API获取当前时间
项目经理如何与甲方沟通