news 2026/4/18 8:36:02

JavaScript DOM

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JavaScript DOM

一、DOM 核心概念:先搞懂「是什么」

DOM(Document Object Model)是浏览器把 HTML/XML 文档转换成的树形对象结构,简单说就是把网页的每一个标签、文本、属性都变成 JavaScript 能操作的「对象」。

  • 类比理解:把网页看作一棵「树」,<html>是根节点,<head>/<body>是分支节点,<div>/<p>/<a>等是子节点,文本、属性是节点的「属性 / 内容」。
  • 核心作用:JavaScript 通过 DOM 可以动态修改网页内容、样式、结构,实现交互(比如点击按钮换内容、输入框实时验证、动态加载数据)。

二、DOM 核心操作:四大核心能力(附代码示例)

1. 查找 / 获取 DOM 元素(最基础,先找到才能操作)

这是所有 DOM 操作的第一步,常用方法如下:

javascript

运行

// 1. 通过ID获取(唯一,返回单个元素) const box = document.getElementById('box'); // 2. 通过类名获取(返回元素数组) const items = document.getElementsByClassName('item'); // 3. 通过标签名获取(返回元素数组) const ps = document.getElementsByTagName('p'); // 4. 通过选择器获取(最灵活,CSS选择器语法) const btn = document.querySelector('#btn'); // 单个元素(第一个匹配项) const lis = document.querySelectorAll('ul li'); // 所有匹配元素(伪数组)
2. 修改 DOM 元素(内容、样式、属性)

找到元素后,可修改其内容、样式、属性,实现动态效果:

javascript

运行

// ① 修改内容 const title = document.querySelector('#title'); title.innerText = '新的标题'; // 纯文本(推荐,防XSS) title.innerHTML = '<span style="color:red">带标签的标题</span>'; // 解析HTML标签 // ② 修改样式(行内样式,优先级高) title.style.color = 'blue'; title.style.fontSize = '24px'; // 注意:CSS的-连接符转驼峰 // ③ 修改CSS类(推荐,批量样式管理) title.classList.add('active'); // 添加类 title.classList.remove('active'); // 移除类 title.classList.toggle('active'); // 切换类(有则删,无则加) // ④ 修改属性 const img = document.querySelector('img'); img.src = 'new-img.jpg'; // 修改图片地址 img.alt = '新图片'; // 修改alt属性
3. 添加 / 删除 DOM 元素(修改页面结构)

可动态创建、插入、删除元素,实现「新增内容」「删除内容」:

javascript

运行

// ① 创建新元素 const newDiv = document.createElement('div'); newDiv.innerText = '我是新增的div'; newDiv.classList.add('new-item'); // ② 插入元素(放到某个父元素里) const container = document.querySelector('#container'); container.appendChild(newDiv); // 插入到父元素最后 container.insertBefore(newDiv, container.firstChild); // 插入到第一个子元素前 // ③ 删除元素 container.removeChild(newDiv); // 父元素删除子元素 newDiv.remove(); // 元素自身删除(更简单)
4. 监听 DOM 事件(实现交互)

给元素绑定事件(点击、鼠标移入、输入等),触发时执行代码:

javascript

运行

const btn = document.querySelector('#btn'); // 方式1:直接绑定 btn.onclick = function() { alert('按钮被点击了!'); }; // 方式2:addEventListener(推荐,可绑定多个同类型事件) btn.addEventListener('click', function() { // 点击后修改自身文本 this.innerText = '已点击'; // 同时修改其他元素样式 document.querySelector('#box').style.backgroundColor = 'pink'; }); // 常见事件:click(点击)、mouseover(鼠标移入)、input(输入框输入)、load(页面加载完成)

三、实战小案例:完整 DOM 交互 demo

以下是一个综合案例,实现「点击按钮新增列表项,点击列表项删除自身」:

html

预览

<!DOCTYPE html> <html> <head> <style> .list-item { margin: 5px; padding: 5px; border: 1px solid #ccc; } .active { color: red; } </style> </head> <body> <button id="addBtn">新增列表项</button> <ul id="list"></ul> <script> // 1. 获取元素 const addBtn = document.querySelector('#addBtn'); const list = document.querySelector('#list'); // 2. 绑定新增按钮点击事件 addBtn.addEventListener('click', function() { // 创建新列表项 const li = document.createElement('li'); li.className = 'list-item'; li.innerText = `列表项${list.children.length + 1}`; // 给新列表项绑定删除事件 li.addEventListener('click', function() { this.remove(); // 点击自身删除 }); // 插入到列表中 list.appendChild(li); }); </script> </body> </html>

总结

  1. DOM 核心本质:把网页转换成 JS 可操作的树形对象,核心是「找元素→改元素→加 / 删元素→绑事件」。
  2. 常用操作优先级:查找元素优先用querySelector/querySelectorAll(灵活),修改样式优先用classList(易维护),事件绑定优先用addEventListener(多事件兼容)。
  3. 核心注意点:操作 DOM 前必须确保元素已加载(可把 JS 放</body>最后,或用DOMContentLoaded事件),避免「找不到元素」的报错。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 5:40:16

Java毕设选题推荐:基于javaWeb的高校教师管理师资管理系统设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】

java毕业设计-基于springboot的(源码LW部署文档全bao远程调试代码讲解等) 博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、…

作者头像 李华
网站建设 2026/4/15 19:52:31

深度测评10个AI论文写作软件,助本科生轻松搞定毕业论文!

深度测评10个AI论文写作软件&#xff0c;助本科生轻松搞定毕业论文&#xff01; AI工具助力论文写作&#xff0c;告别熬夜苦战 随着人工智能技术的不断进步&#xff0c;越来越多的本科生开始借助AI工具来提升论文写作效率。尤其是在面对毕业论文这种庞大而复杂的任务时&#…

作者头像 李华
网站建设 2026/4/18 5:31:03

自然语言处理入门:借助PyTorch通用镜像快速上手

自然语言处理入门&#xff1a;借助PyTorch通用镜像快速上手 1. 快速启动你的NLP开发环境 你是否曾因为配置深度学习环境而浪费大量时间&#xff1f;安装依赖、版本冲突、CUDA不兼容……这些问题在自然语言处理&#xff08;NLP&#xff09;项目中尤为常见。今天&#xff0c;我…

作者头像 李华
网站建设 2026/4/18 7:40:55

新手必看:Cortex-M连接错误完全指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个新手友好型教程应用&#xff0c;包含&#xff1a;1. 错误解释动画&#xff1b;2. 交互式排查向导&#xff1b;3. 常见问题FAQ&#xff1b;4. 基础配置检查清单。要求使用简…

作者头像 李华