- Javascript 基础教程
- Javascript - 首页
- JavaScript - 路线图
- JavaScript - 概述
- JavaScript - 特性
- JavaScript - 启用
- JavaScript - 放置
- JavaScript - 语法
- JavaScript - Hello World
- JavaScript - Console.log()
- JavaScript - 注释
- JavaScript - 变量
- JavaScript - let 语句
- JavaScript - 常量
- JavaScript - 数据类型
- JavaScript - 类型转换
- JavaScript - 严格模式
- JavaScript - 保留关键字
- JavaScript 运算符
- JavaScript - 运算符
- JavaScript - 算术运算符
- JavaScript - 比较运算符
- JavaScript - 逻辑运算符
- JavaScript - 位运算符
- JavaScript - 赋值运算符
- JavaScript - 条件运算符
- JavaScript - typeof 运算符
- JavaScript - 空值合并运算符
- JavaScript - 删除运算符
- JavaScript - 逗号运算符
- JavaScript - 分组运算符
- JavaScript - yield 运算符
- JavaScript - 展开运算符
- JavaScript - 指数运算符
- JavaScript - 运算符优先级
- JavaScript 控制流
- JavaScript - If...Else
- JavaScript - While 循环
- JavaScript - For 循环
- JavaScript - For...in
- Javascript - For...of
- JavaScript - 循环控制
- JavaScript - Break 语句
- JavaScript - Continue 语句
- JavaScript - Switch Case
- JavaScript - 用户定义的迭代器
- JavaScript 函数
- JavaScript - 函数
- JavaScript - 函数表达式
- JavaScript - 函数参数
- JavaScript - 默认参数
- JavaScript - Function() 构造函数
- JavaScript - 函数提升
- JavaScript - 自执行函数
- JavaScript - 箭头函数
- JavaScript - 函数调用
- JavaScript - Function call()
- JavaScript - Function apply()
- JavaScript - Function bind()
- JavaScript - 闭包
- JavaScript - 变量作用域
- JavaScript - 全局变量
- JavaScript - 智能函数参数
- JavaScript 对象
- JavaScript - Number
- JavaScript - Boolean
- JavaScript - Strings
- JavaScript - Arrays
- JavaScript - Date
- JavaScript - DataView
- JavaScript - Handler
- JavaScript - Math
- JavaScript - RegExp
- JavaScript - Symbol
- JavaScript - Sets
- JavaScript - WeakSet
- JavaScript - Maps
- JavaScript - WeakMap
- JavaScript - 可迭代对象
- JavaScript - Reflect
- JavaScript - TypedArray
- JavaScript - 模板字面量
- JavaScript - 标记模板
- 面向对象 JavaScript
- JavaScript - 对象
- JavaScript - 类
- JavaScript - 对象属性
- JavaScript - 对象方法
- JavaScript - 静态方法
- JavaScript - 显示对象
- JavaScript - 对象访问器
- JavaScript - 对象构造函数
- JavaScript - 原生原型
- JavaScript - ES5 对象方法
- JavaScript - 封装
- JavaScript - 继承
- JavaScript - 抽象
- JavaScript - 多态
- JavaScript - 解构赋值
- JavaScript - 对象解构
- JavaScript - 数组解构
- JavaScript - 嵌套解构
- JavaScript - 可选链
- JavaScript - 全局对象
- JavaScript - Mixins
- JavaScript - 代理
- JavaScript 版本
- JavaScript - 历史
- JavaScript - 版本
- JavaScript - ES5
- JavaScript - ES6
- ECMAScript 2016
- ECMAScript 2017
- ECMAScript 2018
- ECMAScript 2019
- ECMAScript 2020
- ECMAScript 2021
- ECMAScript 2022
- JavaScript 异步
- JavaScript - 异步
- JavaScript - 回调函数
- JavaScript - Promise
- JavaScript - Async/Await
- JavaScript - 微任务
- JavaScript - Promise 化
- JavaScript - Promise 链式调用
- JavaScript - 定时事件
- JavaScript - setTimeout()
- JavaScript - setInterval()
- JavaScript Cookie
- JavaScript - Cookie
- JavaScript - Cookie 属性
- JavaScript - 删除 Cookie
- JavaScript 浏览器 BOM
- JavaScript - 浏览器对象模型
- JavaScript - Window 对象
- JavaScript - Document 对象
- JavaScript - Screen 对象
- JavaScript - History 对象
- JavaScript - Navigator 对象
- JavaScript - Location 对象
- JavaScript - Console 对象
- JavaScript Web API
- JavaScript - Web API
- JavaScript - History API
- JavaScript - Storage API
- JavaScript - Forms API
- JavaScript - Worker API
- JavaScript - Fetch API
- JavaScript - Geolocation API
- JavaScript 事件
- JavaScript - 事件
- JavaScript - DOM 事件
- JavaScript - addEventListener()
- JavaScript - 鼠标事件
- JavaScript - 键盘事件
- JavaScript - 表单事件
- JavaScript - Window/Document 事件
- JavaScript - 事件委托
- JavaScript - 事件冒泡
- JavaScript - 事件捕获
- JavaScript - 自定义事件
- JavaScript 错误处理
- JavaScript - 错误处理
- JavaScript - try...catch
- JavaScript - 调试
- JavaScript - 自定义错误
- JavaScript - 扩展错误
- JavaScript 重要关键字
- JavaScript - this 关键字
- JavaScript - void 关键字
- JavaScript - new 关键字
- JavaScript - var 关键字
- JavaScript HTML DOM
- JavaScript - HTML DOM
- JavaScript - DOM 方法和属性
- JavaScript - DOM 文档
- JavaScript - DOM 元素
- JavaScript - DOM 属性 (Attr)
- JavaScript - DOM 表单
- JavaScript - 更改 HTML
- JavaScript - 更改 CSS
- JavaScript - DOM 动画
- JavaScript - DOM 导航
- JavaScript - DOM 集合
- JavaScript - DOM NodeList
- JavaScript - DOM DOMTokenList
- JavaScript 杂项
- JavaScript - Ajax
- JavaScript - 异步迭代
- JavaScript - Atomics 对象
- JavaScript - rest 参数
- JavaScript - 页面重定向
- JavaScript - 对话框
- JavaScript - 页面打印
- JavaScript - 验证
- JavaScript - 动画
- JavaScript - 多媒体
- JavaScript - 图片地图
- JavaScript - 浏览器
- JavaScript - JSON
- JavaScript - 多行字符串
- JavaScript - 日期格式
- JavaScript - 获取日期方法
- JavaScript - 设置日期方法
- JavaScript - 模块
- JavaScript - 动态导入
- JavaScript - BigInt
- JavaScript - Blob
- JavaScript - Unicode
- JavaScript - 浅拷贝
- JavaScript - 调用栈
- JavaScript - 引用类型
- JavaScript - IndexedDB
- JavaScript - Clickjacking 攻击
- JavaScript - 柯里化
- JavaScript - 图形
- JavaScript - Canvas
- JavaScript - 防抖
- JavaScript - 性能
- JavaScript - 样式指南
JavaScript - DOM 元素
DOM 元素
HTML DOM 元素是文档对象模型元素的首字母缩写。使用 JavaScript,我们可以操作 HTM 元素。我们可以使用 id、属性、标签名称、类名称等访问 HTML 元素。
当网页在浏览器中加载时,它会创建一个DOM 树来表示网页的结构。网页包含各种HTML 元素,您可以使用 JavaScript 中的属性和方法来操作它们。在这里,我们将讨论访问、修改或替换等 DOM 元素。
访问 DOM 元素
您可以使用不同的方法来访问 HTML 元素,如下所示。
使用其“id”获取 HTML 元素
在网页中,每个 HTML 元素都可以具有唯一的 id 值。您可以使用 getElementById() 方法使用 id 访问 HTML 元素。
语法
请按照以下语法使用 getElemenetById() 方法使用其 id 访问 HTML 元素。
document.getElementById('id')
在上述语法中,您需要将“id”替换为元素的实际 id。
示例
在下面的代码中,我们使用 id 访问 div 元素,并使用“innerHTML”属性更改其内部 HTML。
<html>
<body>
<div id = "output"> </div>
<script>
document.getElementById('output').innerHTML =
"The element is accessed using the id.";
</script>
</body>
</html>
输出
The element is accessed using the id.
使用“name”获取 HTML 元素
HTML 可以具有“name”属性。您可以使用 getElementByName() 方法使用“name”属性的值访问 HTML 元素。
语法
请按照以下语法使用 getElementByName() 方法。
document.getElementsByName('name')
在这里,您需要将“name”替换为元素的 name 属性的值。
示例
在下面的代码中,我们使用 name 访问 div 元素。它返回一个包含作为参数传递的 name 的节点数组。
<html>
<body>
<div name = "text"> Hello World! </div>
<div id = "output">The content of the div elment is: </div>
<script>
const divEle = document.getElementsByName('text');
document.getElementById("output").innerHTML += divEle[0].innerHTML;
</script>
</body>
</html>
输出
Hello World! The content of the div elment is: Hello World!
使用“className”获取 HTML 元素
HTML 的 class 属性包含字符串值。单个 HTML 元素也可以具有多个类。您可以使用 getElementByClassName() 方法使用多个类中的任何一个类名访问 HTML 元素。
语法
请按照以下语法使用 getElementByClassName() 方法。
document.getElementsByClassName('className');
在上述语法中,将“className”替换为 elment 的“class”属性的值。
示例
在下面的代码中,我们使用类名访问 div 元素。
<html>
<body>
<div class = "fruit"> Apple </div>
<div id = "output">The name of the fruit is: </div>
<script>
const divEle = document.getElementsByClassName('fruit');
document.getElementById("output").innerHTML += divEle[0].innerHTML;
</script>
</body>
</html>
输出
Apple The name of the fruit is: Apple
使用“tag”名称获取 HTML 元素
每个 HTML 元素都是使用 HTML 标签定义的。您可以使用标签 getElementByTagName() 方法使用标签名称访问 HTML 元素。
语法
请按照以下语法使用 getElementByTagName() 方法。
document.getElementsByTagName('tag');
在以上语法中,将“tag”替换为 HTML 标签,例如“p”、“a”、“img”等。
示例
在下面的代码中,我们使用 getElementTagName() 方法访问 <p> 元素。
它返回 <p> 元素的 Nodelist。
<html>
<body>
<p>This is the first paragraph.</p>
<p>This is the second paragrraph.</p>
<div id = "output"> </div>
<script>
const numbers = document.getElementsByTagName('p');
document.getElementById("output").innerHTML =
"The first 'p' element is: " + numbers[0].innerHTML + "<br>" +
"The second 'p' element is: " + numbers[1].innerHTML;
</script>
</body>
</html>
输出
This is the first paragraph. This is the second paragrraph. The first 'p' element is: This is the first paragraph. The second 'p' element is: This is the second paragrraph.
修改 DOM 元素
JavaScript 允许您修改和替换 HTML DOM 元素。
在本节中,我们将介绍修改 DOM 元素的内容和替换子元素。
修改 DOM 元素的内容
您可以使用元素的“textContent”属性来修改 HTML 元素的文本。但是,您可以使用其他属性(如 innerHTML、outerHTML、outerText 等)来修改 HTML 元素的内容。
语法
请按照以下语法使用 textContent 属性修改 HTML 元素的文本内容。
element.textContent = newText;
在以上语法中,我们将“newText”动态值分配给“textContent”属性,以更新“element”的内容。
示例
在输出中,当您单击按钮时,它将调用 updateText() 函数并使用 textContent 属性更改 div 元素的文本。
<html>
<body>
<button onclick = "updateText()"> Update Text </button>
<p id = "text"> Hello World! </p>
<script>
function updateText() {
document.getElementById("text").textContent = "This is updaetd text!";
}
</script>
</body>
</html>
替换子元素
在 JavaScript 中,您可以使用 replaceChild() 方法替换特定 HTML 元素的子元素。
语法
请按照以下语法在 JavaScript 中使用 replaceChild() 方法。
textDiv.replaceChild(newNode,replacableNode);
replaceChild() 方法将新节点作为第一个参数,将需要替换的节点作为第二个参数。
示例
在下面的代码中,我们使用 replaceChild() 方法将 div 元素的第二个子元素替换为一个新节点。在这里,我们还使用了 createTextNode() 创建了一个包含“Hello World!”文本的新节点。
<html>
<body>
<button onclick = "replaceText()"> Replace Child </button>
<div id = "text">
<p> Hi Users! </p>
</div>
<script>
function replaceText() {
let textDiv = document.getElementById("text");
let newText = document.createTextNode("Hello World");
textDiv.replaceChild(newText, textDiv.childNodes[1]);
}
</script>
</body>
</html>
向 DOM 元素添加事件
您可以使用 addEventListner() 方法向 DOM 元素添加事件,以与 HTML 元素进行交互。
语法
请按照以下语法使用 addEventListner() 方法。
element.addEventListener(eventName, callback);
addEventListner() 方法将事件名称作为第一个参数,将回调函数作为第二个参数。
示例
我们在下面的代码中为 div 元素添加了 click 事件。每当您单击 div 元素时,它都会在网页上打印一条消息。
<html>
<body>
<div id = "text" style = "background-color: red;color:white">
<p> Some text </p>
<p> Some other text </p>
</div>
<div id = "output"> </div>
<script>
let text = document.getElementById("text");
text.addEventListener("click", function () {
document.getElementById("output").innerHTML =
"You clicked on the div element";
});
</script>
</body>
</html>
JavaScript DOM 元素方法列表
下表显示了 JavaScript DOM 元素方法列表 -
| 序号 | 方法及描述 |
|---|---|
| 1. | toString()
用于将 HTML 元素转换为字符串格式。 |
| 2. | setAttribute()
此方法允许您为特定元素定义属性。 |
| 3. | setAttributeNode()
此方法允许您在特定元素上定义特定属性节点。 |
| 4. | scrollIntoView()
它确保可滚动容器网页上的特定元素通过调整滚动位置变得可见。 |
| 5. | querySelector()
用于选择和访问文档中与给定 CSS 选择器匹配的第一个 HTML 元素。 |
| 6. | querySelectorAll()
此方法允许您选择和访问文档中与给定 CSS 选择器匹配的所有 HTML 元素。 |
| 7. | remove()
此方法可以完全从网页中删除元素。 |
| 8. | removeAttribute()
此方法用于删除已在 DOM 结构中 HTML 元素上设置的任何属性。 |
| 9. | removeAttributeNode()
它允许您从元素中删除特定的属性节点。 |
| 10. | removeChild()
用于从其父元素中删除选定的子元素。 |
| 11. | removeEventListener()
此方法允许您删除先前分配给元素的事件侦听器。 |
| 12. | replaceChild()
此方法使我们能够用另一个子元素替换父元素中的一个子元素。 |
| 13. | hasAttribute()
用于检查 HTML 元素中是否存在属性。 |
| 14. | hasAttributes()
此方法检查 HTML DOM 中的元素是否具有属性。 |
| 15. | hasChildNodes()
用于检查 HTML 元素内部是否有任何子元素。 |
| 16. | getAttribute()
它返回属于 HTML 元素的指定属性的值。 |
| 17. | getBoundingClientRect()
此方法用于获取元素的大小及其相对于视口的位置。 |
| 18. | closest()
此方法返回当前元素(或当前元素本身)与给定 CSS 选择器匹配的最接近的祖先。如果不存在这样的祖先,则返回 null。 |
| 19. | contains()
您可以使用此方法检查 DOM 元素在其子树中是否包含另一个元素。 |
| 20. | click()
click() 方法在元素上激活鼠标点击。 |
| 21. | normalize()
它用于通过删除任何空文本节点来组合 HTML 元素内的相邻文本节点。 |
| 22. | isDefaultNamespace()
它用于检查特定的命名空间 URI 是否是文档或元素中元素的默认命名空间。 |
| 23. | isEqualNode()
此方法通过比较其属性、类型和子节点来检查两个节点是否相等。 |
| 24. | isSameNode()
它检查两个节点引用是否指向 HTML 文档中的同一个节点对象。 |
| 25. | isSupported()
此方法用于检查 Web 浏览器是否可以支持或处理网页上的特定功能。 |
| 26. | insertAdjacentElement()
此方法允许您在网页上相对于另一个元素的位置精确插入新的 HTML 元素。 |
| 27. | insertBefore()
此方法允许您在父元素内添加新的子元素,并指定其相对于另一个子元素的位置。 |
| 28. | blur()
此方法允许您动态地从 HTML DOM 中的元素中移除焦点。 |
| 29. | matches()
此方法检查元素是否与给定的 CSS 选择器匹配。 |
| 30. | insertAdjacentHTML()
它帮助您在相对于调用此方法的元素的特定位置插入指定的 HTML 代码。 |
| 31. | addEventListener()
它用于向元素注册事件处理程序。 |
| 32. | cloneNode()
它复制节点,包括其属性和子节点。 |
| 33. | appendChild()
此方法用于将新的子节点(元素)作为指定父节点的最后一个子节点添加。 |
| 34. | compareDocumentPosition()
它可以通过比较两个 DOM 元素(节点)的位置来理解文档结构,并返回一个位掩码(数值)。 |
| 35. | focus()
此方法将焦点设置到特定的网页元素。 |
| 36. | getAttributeNode()
它用于获取属性节点对象。 |
| 37. | getBoundingClientRect()
此方法用于获取元素的大小及其相对于视口的位置。 |
| 38. | getElementsByClassName()
此方法检索与文档或特定元素中指定的类名匹配的元素的实时 HTMLCollection。 |
| 39. | getElementsByTagName()
它检索与指定标签名称匹配的元素的实时 HTMLCollection。 |
| 40. | insertAdjacentText()
它允许您在相对于调用此方法的元素的特定位置插入文本内容。 |
JavaScript DOM 元素属性列表
下表包含 JavaScript DOM 元素属性列表 -
| 序号 | 属性及描述 |
|---|---|
| 1. | title
它帮助我们访问和更新存储在元素的 title 属性中的值。 |
| 2. | textContent
此属性用于访问和更新 HTML 元素及其所有子元素的文本内容,作为一个字符串。 |
| 3. | tagName
它以大写形式提供定义网页上元素的 HTML 标签的名称。 |
| 4. | style
使用此属性,您可以获取直接为特定元素设置的 CSS 样式。 |
| 5. | tabIndex
它用于访问和更新元素的 tabIndex 属性的值。 |
| 6. | scrollLeft
此属性用于访问和更新元素内容水平滚动的距离。 |
| 7. | scrollTop
它用于访问和更新元素内容垂直滚动的距离。 |
| 8. | scrollWidth
此属性以像素为单位提供元素内容的总水平宽度。 |
| 9. | scrollHeight
您可以使用此属性以像素为单位获取元素内容的总垂直高度。 |
| 10. | id
id 属性用于设置和检索元素的 id 属性的值。 |
| 11. | innerText
它允许我们检索或更改网页上 HTML 元素内的可见文本内容。 |
| 12. | isContentEditable
它用于检查网页元素是否可以直接由用户编辑。 |
| 13. | lang
lang 属性是 HTML 元素的属性,用于指定语言代码。 |
| 14. | lastChild
lastChild 属性返回一个指向特定父元素的最后一个子节点的节点。 |
| 15. | lastElementChild
它返回一个包含父元素的最后一个子元素的节点。 |
| 16. | namespaceURI
元素的 namespaceURI 属性提供分配给元素的命名空间 URI。 |
| 17. | nextElementSibling
使用此属性,您可以获取特定元素序列中的下一个节点。 |
| 18. | nextSibling
它用于访问 DOM 树中当前节点的下一个节点。 |
| 19. | nodeName
此属性用于根据节点内容识别节点的类型和名称。 |
| 20. | nodeType
nodeType 属性返回一个整数,表示节点的类型。 |
| 21. | nodeValue
它用于访问和更新节点的值。 |
| 22. | offsetHeight
此属性用于获取网页上该元素的完整可见高度,包括其垂直填充和边框,以像素为单位。 |
| 23. | offsetLeft
它返回元素的左边界与其最近的定位父元素的左边界之间的距离(以像素为单位)。 |
| 24. | offsetParent
它用于查找影响另一个元素定位的最接近的祖先元素。 |
| 25. | offsetWidth
元素的 offsetWidth 属性提供网页上该元素的总可见宽度。 |
| 26. | outerHTML
outerHTML 属性获取元素的整个 HTML 代码。 |
| 27. | outerText
此属性可以访问或更新 HTML 元素的文本内容,包括其所有嵌套文本和元素。 |
| 28. | ownerDocument
它为您提供包含特定元素的文档节点的对象。 |
| 29. | parentElement
它允许您访问 HTML 元素内特定元素的直接父元素。 |
| 30. | parentNode
此属性用于访问 HTML 元素内特定节点的直接父节点。 |
| 31. | classList
它充当一个活动容器,其中包含分配给元素的 class 属性的 CSS 类集合。 |
| 32. | childNodes
它用于检索元素的所有子节点,包括元素、文本节点和注释。 |
| 33. | className
您可以使用此属性访问或修改元素的 class 属性的值。 |
| 34. | clientTop
它用于在网页布局中获取准确的元素定位和大小计算。 |
| 35. | firstElementChild
它提供给定父元素内的第一个子元素。 |
| 36. | offsetTop
使用此属性,您可以获取元素的顶部边缘与其最近的定位祖先的顶部边缘之间的垂直距离(以像素为单位)。 |
| 37. | attributes
它返回包含 HTML 元素属性集合的“NameNodeMap”。 |
| 38. | accesskey
此属性允许您为网页上的元素分配键盘快捷键。 |
| 39. | firstChild
它帮助您访问 HTML DOM 中给定父元素的第一个子节点。 |
| 40. | innerHTML
此属性允许我们读取元素的现有 HTML 内容并使用新的 HTML 内容更新它。 |
| 41. | dir
它提供访问权限,用于设置和检索 HTML 中任何元素的 dir 属性的值。 |
| 42. | contentEditable
您可以使用此属性使 HTML 元素内的文本内容可编辑。 |
| 43. | clientWidth
它返回元素的宽度,包括内边距,但不包括外边距、边框或滚动条宽度。 |
| 44. | clientLeft
此属性用于获取元素左侧边框的宽度,不包括左侧内边距或外边距。 |
| 45. | clientHeight
它用于获取元素的内部高度,包括内边距,但不包括外边距、边框或滚动条宽度。 |
| 46. | children
此属性返回子元素的集合。 |
| 47. | childElementCount
它返回指定元素的直接子元素的数量。 |