零基础快速入门前端DOM 操作核心知识与实战解析(完整汇总版)(可用于备赛蓝桥杯Web应用开发)

零基础快速入门前端DOM 操作核心知识与实战解析(完整汇总版)(可用于备赛蓝桥杯Web应用开发)

DOM(Document Object Model,文档对象模型)是 JavaScript 操作 HTML 文档的桥梁,它将网页转换为一棵 “树”,每个 HTML 标签、属性、文本都是树上的节点。掌握 DOM 操作,就能动态改变网页内容、样式和交互。本文结合实战代码,从基础到进阶系统梳理 DOM 核心知识。

一、DOM 元素获取:找到要操作的 “节点”

操作 DOM 的第一步是 “找到元素”,常用方法如下:

方法

描述

示例

querySelector()

通过 CSS 选择器获取单个元素

document.querySelector(".div1")

getElementById()

通过 id 获取单个元素

document.getElementById("dd")

querySelectorAll()

通过 CSS 选择器获取所有元素

document.querySelectorAll("div")

代码示例

var div1 = document.querySelector(".div1"); // 获取 class 为 div1 的第一个元素 var div2 = document.querySelector(".div2");

二、DOM 属性操作:修改标签的 “固有属性” 与 “自定义属性”

1. 固有属性操作

HTML 标签的固有属性(如 idsrchref)可通过 元素.属性名 直接修改。

代码示例:切换 div1id 属性

function div1Click() { if (div1.id == "dd") { div1.id = "dd2"; // 直接修改 id 属性 } else { div1.id = "dd"; } }

2. 自定义属性操作

除了固有属性,还可给元素添加自定义属性(如代码中的 index)存储数据,常用方法:

方法

描述

示例

setAttribute(name, value)

设置自定义属性(或修改固有属性)

div1.setAttribute('index', 0)

getAttribute(name)

获取属性值(支持自定义 / 固有属性)

div1.getAttribute('index')

代码示例:给元素添加 index 属性并读取

var div1 = document.querySelector('.div1'); div1.setAttribute('index', 0); // 设置自定义属性 function div1Click(tt) { var index = tt.getAttribute('index'); // 读取 index tt.classList.add('bg' + index); // 动态添加类名 }

三、DOM 样式操作:改变元素的 “外观”

修改样式有两种常用方式:

  1. style 属性:适合修改单个样式(CSS 属性名需转 “驼峰命名”,如 font-sizefontSize)。
  2. className/classList:适合批量修改样式(通过操作 CSS 类名实现)。

代码示例 1:用 style 修改单个样式

function div2Click() { div2.style.color = "red"; // 修改文字颜色 div2.style.fontSize = "25px"; // 修改字体大小(驼峰命名) div2.style.backgroundColor = "yellow"; // 修改背景色 }

代码示例 2:用className 批量添加类

div2.className += " div22"; // 给 div2 追加类名 div22(注意空格!)

代码示例 3:用classList 更灵活地操作类

function div4Click() { div3.classList.add('div33'); // 添加类 if (div3.className.includes("div333")) { div3.classList.remove('div333'); // 移除类 } else { div3.classList.add("div333"); // 切换类 } }

四、DOM 事件处理:让网页 “动起来”(含三种绑定方式)

事件是用户与网页交互的核心,本文代码展示了 三种事件绑定方式,各有特点:

1. 行内绑定:直接在 HTML 标签中写 onclick

通过 onclick="函数名(this)" 绑定,可传递 this 代表当前元素。

<div onclick="div1Click(this)">点击我</div>
function div1Click(tt) { // tt 就是点击的元素本身 var index = tt.getAttribute('index'); tt.classList.add('bg' + index); }

2. 属性绑定:通过 元素.onclick = 函数 绑定(最常用)

直接在 JS 中给元素的 onclick 属性赋值函数,代码与 HTML 分离。

var div3 = document.querySelector(".div3"); div3.onclick = function() { console.log("div3 被点击了"); // 这里的 this 指向 div3 本身 };

3. addEventListener:更灵活的事件监听

支持绑定多个事件处理函数,不会覆盖之前的绑定。

var div4 = document.querySelector('.div4'); div4.setAttribute('index', 3); div4.addEventListener('click', function() { var index = this.getAttribute('index'); // this 指向 div4 this.classList.add('bg' + index); });

五、this 关键字:谁调用就指向谁

在 DOM 操作中,this 的指向核心规律是:谁调用事件 / 函数,this 就指向谁

绑定方式

this 指向

示例

行内绑定(传 this

当前点击的元素

div1Click(this)tt 是元素

属性绑定(onclick

当前调用的元素

div3.onclick = function(){...}this 是 div3

addEventListener

当前触发事件的元素

div4.addEventListener('click', ...)this 是 div4

代码示例this 在属性绑定中的应用

var div5 = document.querySelector(".div5"); div5.setAttribute('index', 4); div5.onclick = function() { var index = this.getAttribute('index'); // this 指向 div5 this.classList.add('bg' + index); };

六、DOM 核心知识汇总表

操作类型

方法 / 属性

示例

说明

获取元素

querySelector()

document.querySelector(".div1")

获取单个元素(CSS 选择器)

getElementById()

document.getElementById("dd")

通过 id 获取元素

querySelectorAll()

document.querySelectorAll("div")

获取所有匹配元素

修改属性

元素.属性名

div1.id = "dd2"

修改标签固有属性

自定义属性

setAttribute()

div1.setAttribute('index', 0)

设置自定义属性

getAttribute()

div1.getAttribute('index')

获取属性值(支持自定义)

修改样式

style

div2.style.color = "red"

修改单个样式(驼峰命名)

className

div2.className += " div22"

批量追加类名

classList

div3.classList.add('div33')

灵活添加 / 移除类

事件绑定

行内绑定

<div onclick="div1Click(this)">

HTML 中直接绑定(传 this

属性绑定

div3.onclick = function(){...}

JS 中绑定(常用)

addEventListener

div4.addEventListener('click', ...)

可绑定多个函数

this 指向

事件绑定中

this.getAttribute('index')

指向调用事件的元素

Read more

1.5k stars!阿里开源 PageAgent:让 AI 直接“住进“你的网页,用自然语言操控一切!

1.5k stars!阿里开源 PageAgent:让 AI 直接“住进“你的网页,用自然语言操控一切!

阿里开源 PageAgent:让 AI 直接"住进"你的网页,用自然语言操控一切 不需要浏览器插件,不需要 Python,不需要截图——一行 JS,让你的网页秒变 AI 智能体。 一、先说痛点:Web 自动化为什么这么难? 如果你用过 Selenium、Playwright,或者最近流行的 browser-use,你一定遇到过这些头疼的问题: * 环境太重:得装 Python、headless 浏览器、各种依赖,部署复杂,维护成本高; * 依赖截图 + OCR:很多方案靠多模态模型"看图操作",慢、贵、还不准; * 权限门槛高:要控制浏览器,往往需要特殊权限甚至操作系统级别的访问; * 对现有产品改造成本大:

你以为你在部署 AI 助手,其实也可能在打开一扇“数据侧门”:OpenClaw 安全风险全解析

你以为你在部署 AI 助手,其实也可能在打开一扇“数据侧门”:OpenClaw 安全风险全解析

🔥 个人主页:杨利杰YJlio❄️ 个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》《Python》《Kali Linux》《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更简单,让重复的工作自动化 你以为你在部署 AI 助手,其实也可能在打开一扇“数据侧门”:OpenClaw 安全风险全解析 * * 1、你以为你在装 AI 助手,其实你可能在给系统加一个“高权限自动化入口” * 2、OpenClaw 和普通 AI 最大的区别,到底在哪里? * 3、我为什么说:OpenClaw 更像“拿到部分权限的数字操作员”? * 4、为什么说 AI 助手不是“更聪明的搜索框”? * 5、OpenClaw 的 5

GitHub Copilot for Java:上下文感知重构建议实操

GitHub Copilot for Java:上下文感知重构建议实操

在Java开发过程中,代码重构是提升代码质量、降低维护成本的核心环节。无论是面对遗留系统的技术债,还是优化日常开发中的冗余代码,传统重构方式往往需要开发者花费大量时间梳理逻辑、排查隐患。而GitHub Copilot作为AI驱动的编程助手,其强大的上下文感知能力能精准捕捉代码语义、业务逻辑和潜在问题,为Java重构提供智能化建议。本文将从实操角度出发,结合多个典型场景,带大家掌握GitHub Copilot在Java重构中的使用技巧,同时拓展其背后的核心原理与最佳实践。 一、基础准备:搭建Copilot Java重构环境 在开始重构实操前,需完成GitHub Copilot与Java开发工具的集成。目前Copilot支持Visual Studio Code(VS Code)、IntelliJ IDEA等主流IDE,以下以应用广泛的VS Code为例,说明环境搭建步骤: 1. 订阅与授权:访问GitHub Copilot官网完成订阅,使用GitHub账号登录并授权IDE访问权限; 2. 插件安装:在VS Code扩展商店搜索“GitHub Copilot”,点击安装并重启ID

paperxie 文献综述:硕士学术进阶的智能写作 “加速器”

paperxie 文献综述:硕士学术进阶的智能写作 “加速器”

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/journalsReviewedhttps://www.paperxie.cn/ai/journalsReviewedhttps://www.paperxie.cn/ai/journalsReviewed 在硕士阶段的学术成长路径中,文献综述从来都不是简单的文献堆砌,而是一场对研究领域的深度 “考古” 与逻辑 “编织”。它要求研究者在浩如烟海的学术文献中,梳理出清晰的脉络、精准的问题意识和严谨的论证框架。但对许多硕士生而言,面对成百上千篇文献、复杂的学术观点碰撞,以及 “述” 与 “评” 的平衡难题,文献综述常常成为科研路上的 “拦路虎”。如今,paperxie 论文写作平台的硕士文献综述写作功能,正以技术赋能学术,为硕士生打造出一条更高效、更专业的文献综述创作路径。 一、硕士文献综述的 “隐形门槛”