news 2026/4/23 16:21:33

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/23 10:48:42

Z-Image-Turbo上手全记录:无需下载,启动即用超省心

Z-Image-Turbo上手全记录&#xff1a;无需下载&#xff0c;启动即用超省心 你有没有过这样的经历&#xff1f; 想用AI生成一张“穿汉服的少女在江南庭院赏雪”的图&#xff0c;结果模型加载失败、中文提示被误解、等了半分钟只出了一张模糊变形的作品。更别提还要手动配置环境、…

作者头像 李华
网站建设 2026/4/23 7:49:20

TexStudio实战:从零开始撰写学术论文的完整指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个基于TexStudio的学术论文写作辅助工具&#xff0c;包含&#xff1a;1) 常见期刊/会议模板库 2) 智能章节结构生成器 3) 图表自动编号和引用系统 4) BibTeX参考文献管理界面…

作者头像 李华
网站建设 2026/4/23 10:43:57

【高效写作必备】:Top 3 VSCode Markdown实时预览插件深度测评

第一章&#xff1a;VSCode Markdown实时预览插件概述 Visual Studio Code&#xff08;简称 VSCode&#xff09;作为当前最受欢迎的代码编辑器之一&#xff0c;凭借其高度可扩展性与丰富的插件生态&#xff0c;成为开发者撰写技术文档和笔记的首选工具。其中&#xff0c;Markdow…

作者头像 李华
网站建设 2026/4/23 12:10:48

再也不用手动刷新!VSCode Markdown实时预览技巧,秒级响应

第一章&#xff1a;再也不用手动刷新&#xff01;VSCode Markdown实时预览技巧&#xff0c;秒级响应VSCode 内置的 Markdown 预览功能默认为手动触发&#xff08;CtrlShiftV 或右键 → “Open Preview”&#xff09;&#xff0c;但通过合理配置与插件协同&#xff0c;可实现真正…

作者头像 李华
网站建设 2026/4/23 10:45:03

从1小时到10分钟:Advanced Installer效率提升技巧

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个效率优化工具包&#xff0c;包含&#xff1a;1) Advanced Installer常用操作快捷键指南 2) 模板库&#xff08;各种常见安装场景的预设配置&#xff09; 3) 批量处理脚本&…

作者头像 李华
网站建设 2026/4/23 8:09:46

AI如何帮你轻松实现完全二叉树算法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 使用AI生成一个完全二叉树的实现代码&#xff0c;要求包含以下功能&#xff1a;1. 插入节点&#xff1b;2. 删除节点&#xff1b;3. 前序、中序、后序遍历&#xff1b;4. 判断是否…

作者头像 李华