本博客相关参考文档 :
在之前的博客中 , 都是通过 ID、 标签名、类名 获取 HTML 网页中的 DOM 元素 , 分别使用
上述获取 DOM 元素的函数 , 需要根据不同的 CSS 选择器 , 使用不同的函数 ;
在 HTML5 中 , DOM API 推出了新的方法 querySelector 函数 , 可以在该函数参数中指定 " CSS 选择器 " , 函数返回匹配该选择器的第一个 DOM 元素 , 如果没有与之匹配的元素 , 返回 null 值 ;
Document 和 Element 都定义了 querySelector 函数 , 分别从 HTML 文档 和 Element 元素 中查询 指定 符合 CSS 选择器 的 第一个 DOM 元素 , 只能获取一个 Element 元素 ;
document.querySelector 函数原型如下 :
var element = document.querySelector(selectors);
CSS 选择器参考 :
给定如下 HTML 标签 :
<div id="hello">Hello1</div>
<div>Hello</div>
<div class="text">Hello</div>
<div id="nav">
<div class="text">Hello2</div>
<div>Hello2</div>
<div>Hello2</div>
</div>
使用 ID 选择器 #hello
可以获取 ID 为 hello 的 DOM 元素 ;
// 只获取 id 为 hello 的元素 ★
var element = document.querySelector('#hello');
使用符合选择器 获取 ID 为 nav 的容器下的 text 类的元素 ;
// 获取 id 为 nav 元素下的 text 类的元素 ★
element = document.querySelector('#nav .text');
代码示例 :
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<!-- 设置 meta 视口标签 -->
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no,maximum-scale=1.0,minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>JavaScript</title>
<style></style>
</head>
<body>
<div id="hello">Hello1</div>
<div>Hello</div>
<div class="text">Hello</div>
<div id="nav">
<div class="text">Hello2</div>
<div>Hello2</div>
<div>Hello2</div>
</div>
<script>
// 注意 : HTML 文档加载顺序是从上到下加载
// 这里要先加载标签 , 然后加载 JavaScript 脚本
// 只获取 id 为 hello 的元素 ★
var element = document.querySelector('#hello');
// 控制台打印获取结果
console.log(element);
// 获取 id 为 nav 元素下的 text 类的元素 ★
element = document.querySelector('#nav .text');
// 控制台打印获取结果
console.log(element);
// 获取 文档中的 text 类的元素 ★
element = document.querySelector('.text');
// 控制台打印获取结果
console.log(element);
</script>
</body>
</html>
执行结果 :
Document 和 Element 都定义了 querySelectorAll 函数 , 分别从 HTML 文档 和 Element 元素 中查询 所有 指定符合 CSS 选择器 的 DOM 元素 ;
document.querySelectorAll 函数原型如下 :
var element = document.querySelectorAll(selectors);
NodeList 对象 与 HTMLCollection 对象类似 , 都封装了若干 Element 对象 ;
参考文档 :
完整代码示例 :
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<!-- 设置 meta 视口标签 -->
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no,maximum-scale=1.0,minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>JavaScript</title>
<style></style>
</head>
<body>
<div id="hello">Hello1</div>
<div>Hello</div>
<div class="text">Hello</div>
<div id="nav">
<div class="text">Hello2</div>
<div>Hello2</div>
<div>Hello2</div>
</div>
<script>
// 注意 : HTML 文档加载顺序是从上到下加载
// 这里要先加载标签 , 然后加载 JavaScript 脚本
// 获取 id 为 nav 元素下的 text 类的元素 ★
var elements = document.querySelectorAll('#nav div');
// 控制台打印获取结果
console.log(elements);
// 获取 文档中的 text 类的元素 ★
elements = document.querySelectorAll('.text');
// 控制台打印获取结果
console.log(elements);
</script>
</body>
</html>
执行结果 :
在上述 querySelectorAll 函数 中 , 获取的符合 指定选择器 的 所有 DOM 元素 , 返回值的类型是 NodeList 对象 ;
NodeList 对象 与 HTMLCollection 对象类似 , 都封装了若干 Element 对象 , 都是 类数组 ( Like Array Object ) 对象 , 可使用 数组下标的方式进行访问 ;
NodeList 对象 与 HTMLCollection 对象 的区别是 :
参考文档 :
使用数组下标的方式 , 可遍历 NodeList 对象 :
// 获取 id 为 nav 元素下的 text 类的元素 ★
var elements = document.querySelectorAll('#nav div');
// 控制台打印获取结果
console.log(elements);
// 使用数组下标方式遍历 NodeList 对象
for (var i = 0; i < elements.length; ++i) {
var item = elements[i];
console.log(item);
}
代码示例 :
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<!-- 设置 meta 视口标签 -->
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no,maximum-scale=1.0,minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>JavaScript</title>
<style></style>
</head>
<body>
<div id="hello">Hello1</div>
<div>Hello</div>
<div class="text">Hello</div>
<div id="nav">
<div class="text">Hello2</div>
<div>Hello2</div>
<div>Hello2</div>
</div>
<script>
// 注意 : HTML 文档加载顺序是从上到下加载
// 这里要先加载标签 , 然后加载 JavaScript 脚本
// 获取 id 为 nav 元素下的 text 类的元素 ★
var elements = document.querySelectorAll('#nav div');
// 控制台打印获取结果
console.log(elements);
// 使用数组下标方式遍历 NodeList 对象
for (var i = 0; i < elements.length; ++i) {
var item = elements[i];
console.log(item);
}
</script>
</body>
</html>
执行结果 :