DOM基础入门介绍了DOM的基本概念和核心特点,包括DOM的层次结构和动态性,以及DOM与HTML之间的关系。文章详细讲解了如何选择和访问DOM元素,包括使用ID、类名、标签名和CSS选择器。同时,文章还涵盖了DOM元素的属性操作、文本内容操作和样式操作,以及元素的创建、插入和删除方法。
1. DOM基础概念介绍1.1 什么是DOM?
文档对象模型(Document Object Model,DOM)是一种与平台和语言无关的接口,它将文档视为树形结构,使得程序可以动态地访问和修改文档的内容、结构和样式。在Web开发中,DOM主要用于操作HTML和XML文档。DOM的核心在于它将文档视为一个树形结构,每个节点都是一个对象,每个对象都可以执行特定的方法和属性。通过JavaScript,可以对这些节点进行各种操作,如读取、修改、添加和删除。
1.2 DOM的核心特点
DOM具有以下核心特点:
- 层次结构:DOM将文档视为一个树形结构,每个节点在树中都有一个特定的位置,这使得DOM可以方便地表示和操作文档的结构。
- 动态性:DOM允许开发者在运行时动态地修改文档内容、结构和样式,从而实现丰富的交互效果和用户界面。
- 可访问性:DOM的接口是与平台和语言无关的,这意味着它可以在不同的浏览器和编程语言中工作,大大提高了跨平台的兼容性。
- 事件处理:DOM提供了丰富的事件处理功能,可以监听和响应用户操作,如鼠标点击、键盘输入等,增强了交互性。
1.3 DOM和HTML的关系
DOM和HTML之间有密切的关系:
- 文档表示:HTML文件是文档的文本表示形式,而DOM是该文档的树形结构表示。HTML文件被浏览器解析后,会生成一个DOM树,每个HTML标签在DOM树中都有一个对应的节点。
- 节点类型:DOM中节点的类型与HTML标签类型相对应。例如,HTML元素标签如
<div>
、<span>
等在DOM中表现为元素节点,而文本内容则表现为文本节点。 - 属性操作:DOM允许通过JavaScript操作HTML元素的属性,例如获取、设置和删除元素的属性值。
- 事件处理:DOM中的事件处理机制允许JavaScript对HTML元素上的事件进行监听和响应,例如当用户点击某个按钮时,触发相应的事件处理器。
DOM和HTML的关系示例
<!DOCTYPE html>
<html>
<head>
<title>DOM和HTML关系示例</title>
</head>
<body>
<div id="myDiv">
<p>Hello, DOM!</p>
</div>
<script>
// 通过DOM访问HTML元素
var myDiv = document.getElementById("myDiv");
console.log(myDiv); // 输出: <div id="myDiv">...</div>
// 通过DOM操作HTML元素
myDiv.innerHTML = "<p>DOM 已修改内容。</p>";
</script>
</body>
</html>
在上述示例中,HTML文件被解析为DOM树,其中<div>
标签在DOM中被表示为一个元素节点。JavaScript通过getElementById
方法获取到<div>
元素,并通过设置innerHTML
属性来修改其内容。
2.1 使用ID和类名选择元素
ID选择器
ID选择器通过元素的id
属性选择唯一的一个DOM元素。ID在HTML文档中必须是唯一的。
类名选择器
类名选择器通过元素的class
属性选择一个或多个DOM元素。类名可以在HTML文档中重复使用。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>选择DOM元素示例</title>
<style>
.highlight { color: red; }
</style>
</head>
<body>
<div id="myDiv1">这是ID选择的元素</div>
<div class="highlight">这是类名选择的元素1</div>
<div class="highlight">这是类名选择的元素2</div>
<script>
// 通过ID选择元素
var myDiv1 = document.getElementById("myDiv1");
console.log(myDiv1); // 输出: <div id="myDiv1">这是ID选择的元素</div>
// 通过类名选择元素
var highlights = document.getElementsByClassName("highlight");
for (var i = 0; i < highlights.length; i++) {
console.log(highlights[i]); // 输出: <div class="highlight">...</div>
}
</script>
</body>
</html>
示例解释
在上述示例中,通过getElementById
方法获取到id
为myDiv1
的<div>
元素。使用getElementsByClassName
方法获取到所有class
为highlight
的<div>
元素,然后通过循环输出这些元素。
2.2 使用标签名选择元素
标签名选择器通过元素的标签名选择一个或多个DOM元素。这种方式返回的是一个节点列表。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>选择DOM元素示例</title>
</head>
<body>
<p>这是标签名选择的元素1</p>
<p>这是标签名选择的元素2</p>
<div>这是其他元素</div>
<script>
var paras = document.getElementsByTagName("p");
for (var i = 0; i < paras.length; i++) {
console.log(paras[i]); // 输出: <p>...</p>
}
</script>
</body>
</html>
示例解释
在上述示例中,通过getElementsByTagName
方法获取到所有<p>
标签元素,然后通过循环输出这些元素。
2.3 使用CSS选择器选择元素
CSS选择器是一种更强大的选择器,支持复杂的组合选择。常用的CSS选择器包括:
- 标签选择器:选择特定标签的所有元素。
- 类选择器:选择具有特定类名的所有元素。
- ID选择器:选择具有特定ID的元素。
- 属性选择器:选择具有特定属性的元素。
- 伪类选择器:选择具有特定状态的元素,如
:hover
、:active
等。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>选择DOM元素示例</title>
<style>
.highlight { color: red; }
</style>
</head>
<body>
<p id="p1">这是标签名选择的元素1</p>
<p id="p2">这是标签名选择的元素2</p>
<div class="highlight">这是类名选择的元素</div>
<script>
// 使用CSS选择器选择元素
var element = document.querySelector("#p1");
console.log(element); // 输出: <p id="p1">这是标签名选择的元素1</p>
var elements = document.querySelectorAll(".highlight");
for (var i = 0; i < elements.length; i++) {
console.log(elements[i]); // 输出: <div class="highlight">...</div>
}
</script>
</body>
</html>
示例解释
在上述示例中,通过querySelector
方法获取到id
为p1
的<p>
元素,通过querySelectorAll
方法获取到所有class
为highlight
的元素,然后通过循环输出这些元素。
3.1 获取元素属性
获取元素属性通常使用getAttribute
方法。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>获取DOM元素属性示例</title>
</head>
<body>
<div id="myDiv" data-custom="custom-value">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
var customValue = myDiv.getAttribute("data-custom");
console.log(customValue); // 输出: custom-value
</script>
</body>
</html>
示例解释
在上述示例中,通过getAttribute
方法获取到id
为myDiv
的<div>
元素的data-custom
属性值。
3.2 设置元素属性
设置元素属性通常使用setAttribute
方法。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>设置DOM元素属性示例</title>
</head>
<body>
<div id="myDiv">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
myDiv.setAttribute("data-custom", "new-value");
console.log(myDiv.getAttribute("data-custom")); // 输出: new-value
</script>
</body>
</html>
示例解释
在上述示例中,通过setAttribute
方法设置id
为myDiv
的<div>
元素的data-custom
属性值为new-value
,然后通过getAttribute
方法获取到该属性值。
3.3 删除元素属性
删除元素属性通常使用removeAttribute
方法。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>删除DOM元素属性示例</title>
</head>
<body>
<div id="myDiv" data-custom="custom-value">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
myDiv.removeAttribute("data-custom");
console.log(myDiv.getAttribute("data-custom")); // 输出: null
</script>
</body>
</html>
示例解释
在上述示例中,通过removeAttribute
方法删除id
为myDiv
的<div>
元素的data-custom
属性,然后通过getAttribute
方法获取到该属性的值为null
,表示属性已被删除。
4.1 获取元素的文本内容
获取元素的文本内容通常使用textContent
或innerText
属性。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>获取DOM元素文本内容示例</title>
</head>
<body>
<div id="myDiv">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
console.log(myDiv.textContent); // 输出: 这是一个div元素
</script>
</body>
</html>
示例解释
在上述示例中,通过textContent
属性获取到id
为myDiv
的<div>
元素的文本内容。
4.2 修改元素的文本内容
修改元素的文本内容通常使用textContent
或innerText
属性。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>修改DOM元素文本内容示例</title>
</head>
<body>
<div id="myDiv">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
myDiv.textContent = "文本内容已修改";
console.log(myDiv.textContent); // 输出: 文本内容已修改
</script>
</body>
</html>
示例解释
在上述示例中,通过textContent
属性设置id
为myDiv
的<div>
元素的新文本内容为“文本内容已修改”,然后通过textContent
属性获取到修改后的文本内容。
4.3 删除元素的文本内容
删除元素的文本内容通常使用textContent
属性。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>删除DOM元素文本内容示例</title>
</head>
<body>
<div id="myDiv">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
myDiv.textContent = "";
console.log(myDiv.textContent); // 输出:
</script>
</body>
</html>
示例解释
在上述示例中,通过textContent
属性将id
为myDiv
的<div>
元素的文本内容设置为空字符串,然后通过textContent
属性获取到该元素的文本内容为空。
5.1 获取元素样式
获取元素样式通常使用style
属性,或者使用getComputedStyle
函数。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>获取DOM元素样式示例</title>
<style>
#myDiv { color: red; }
</style>
</head>
<body>
<div id="myDiv">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
console.log(myDiv.style.color); // 输出: red
var computedStyle = window.getComputedStyle(myDiv);
console.log(computedStyle.color); // 输出: red
</script>
</body>
</html>
示例解释
在上述示例中,通过style
属性获取到id
为myDiv
的<div>
元素的color
样式值,通过getComputedStyle
函数获取到该元素的计算后的color
样式值。
5.2 设置元素样式
设置元素样式通常使用style
属性。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>设置DOM元素样式示例</title>
</head>
<body>
<div id="myDiv">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
myDiv.style.color = "blue";
console.log(myDiv.style.color); // 输出: blue
</script>
</body>
</html>
示例解释
在上述示例中,通过style
属性设置id
为myDiv
的<div>
元素的color
样式值为blue
,然后通过style
属性获取到该元素的color
样式值。
5.3 删除元素样式
删除元素样式通常使用style
属性设置为""
。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>删除DOM元素样式示例</title>
<style>
#myDiv { color: red; }
</style>
</head>
<body>
<div id="myDiv" style="color: red;">这是一个div元素</div>
<script>
var myDiv = document.getElementById("myDiv");
myDiv.style.color = "";
console.log(myDiv.style.color); // 输出: ""
</script>
</body>
</html>
示例解释
在上述示例中,通过style
属性将id
为myDiv
的<div>
元素的color
样式值设置为空字符串,然后通过style
属性获取到该元素的color
样式值为空字符串。
6.1 创建新的DOM元素
创建新的DOM元素通常使用document.createElement
方法。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>创建DOM元素示例</title>
</head>
<body>
<script>
var myDiv = document.createElement("div");
myDiv.id = "myDiv";
myDiv.textContent = "这是一个新创建的div元素";
document.body.appendChild(myDiv); // 将新元素添加到body
</script>
</body>
</html>
示例解释
在上述示例中,通过createElement
方法创建一个新的<div>
元素,然后通过id
属性设置该元素的id
,通过textContent
属性设置该元素的文本内容,最后通过appendChild
方法将新创建的元素添加到body
元素中。
6.2 插入DOM元素到页面中
插入DOM元素通常使用appendChild
、insertBefore
等方法。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>插入DOM元素示例</title>
</head>
<body>
<div id="container">容器</div>
<script>
var container = document.getElementById("container");
var newDiv = document.createElement("div");
newDiv.textContent = "新创建的div元素";
container.appendChild(newDiv); // 将新元素添加到容器元素的末尾
</script>
</body>
</html>
示例解释
在上述示例中,通过getElementById
方法获取到id
为container
的<div>
元素,通过createElement
方法创建一个新的<div>
元素,然后通过textContent
属性设置该元素的文本内容,最后通过appendChild
方法将新创建的元素添加到容器元素的末尾。
6.3 删除DOM元素
删除DOM元素通常使用removeChild
方法。
示例代码
<!DOCTYPE html>
<html>
<head>
<title>删除DOM元素示例</title>
</head>
<body>
<div id="container">
<div id="toDelete">要删除的元素</div>
</div>
<script>
var container = document.getElementById("container");
var toDelete = document.getElementById("toDelete");
container.removeChild(toDelete); // 删除指定元素
</script>
</body>
</html>
示例解释
在上述示例中,通过getElementById
方法获取到id
为container
的<div>
元素,通过getElementById
方法获取到id
为toDelete
的<div>
元素,最后通过removeChild
方法删除该元素。
通过以上内容,你可以详细了解和掌握DOM的基本概念、选择和访问DOM元素的方法、元素属性、文本内容和样式的操作,以及创建、插入和删除DOM元素的方法。这些操作是网页开发中不可或缺的基础技能,掌握它们可以帮助你更好地构建动态的网页和进行交互设计。