DOM讲解
创作时间:
作者:
@小白创作中心
DOM讲解
引用
CSDN
1.
https://m.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 来改变页面内容和结构,这使得现代网页可以响应用户交互,提供丰富的动态效果。
热门推荐
春节打卡海南热带野生动植物园:亲子游必选!
如何拍出朋友圈最火的苏州梅花?
海口必打卡:骑楼老街&海瑞墓的文化之旅
海南环岛旅游公路:海口自然奇观探秘
五一必打卡!海口观海台超全攻略
拙政园赏梅全攻略:雪香云蔚亭畔的梅花盛宴
香雪海:苏州冬日赏梅打卡圣地
苏州梅花提前绽放!最佳观赏期已至
三个维度看济宁:托起稳稳的幸福
盐城:历史与文化的完美融合
探秘盐城古建筑:江苏新晋历史文化名城
西溪景区和淮剧小镇:盐城的文化新地标
Ubuntu 23.10全新发布!手把手教你用U盘安装系统
用U盘快速重装系统,效率翻倍!
公司注册全流程指南:从核名到税务登记
北京四合院:从元代到现代的华丽蜕变
恭王府花园:北京四合院园林设计典范
中式别墅设计:四合院新潮流
海口必打卡十大美食,你吃过几个?
海口必打卡:骑楼老街里的南洋风韵与假日海滩的阳光海浴
骑楼老街探秘:海口历史文化之旅
擅长爬树的猫科动物有什么了不起?看看花豹会爬树的5大好处
适应:应对环境挑战
《热辣滚烫》带火了“动物流”,这种健身方式适合普通人吗?
三省交汇地的运城,原来是个“混搭风”的美食城,好吃的都杂乱了
德国牧羊犬不能喝可乐?真相揭秘!
抚养费不给可以申请强制执行吗
如何申请法律援助
关于孩子抚养费,你不得不知道的知识。
一文详解光伏电站开发建设全流程