登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
1
2
/ 2 页
下一页
返回列表
首页
›
业界区
›
业界
›
Web前端入门第 70 问:JavaScript DOM 节点查找常用方法 ...
Web前端入门第 70 问:JavaScript DOM 节点查找常用方法
[ 复制链接 ]
厨浴
2025-9-24 15:42:31
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
虽然目前的开发场景基本都是使用 React/Vue/Angular 等框架,但是对于一些基础的 DOM 操作,还是需要了解学习。
曾经我们讨论过这样一个问题:Vue 这些开发框架,用它们渲染页面,真的就比不用开发框架快吗?
其实这个问题很好回答的,开发框架只是优化了项目的开发效率,对于浏览器的渲染速度,其实并没有想象中的那么快。
目前的前后端分离的开发模式,大致分为两种:一是浏览器端运行 Vue 等单页应用框架,由前端发起接口请求渲染页面从而实现前后端分离;二是在服务端运行 node.js ,由 node.js 发起接口请求渲染页面,从而实现前后端分离。这两种开发模式都绕不开的一个问题是:都要请求一次接口,http 通信都是很耗时的,相比于古老的后端渲染来说,其实已经算很慢了。
那么就有一个问题:为何 node.js 不直接写 SQL 查询数据库?嘿。。这个问题嘛就涉及到方方面面了,比如全栈开发和前端开发的价格那可不一样,会 JS 的前端和会 SQL 的前端又不一样了,前端踩过线去干后端的事这就矛盾来了...
废话太多了,咱们进入正题~~
DOM 查询
DOM 查询就是要找到 HTML 中的某个节点,方便对这个节点干一些不可描述的事~~
比如说给这个 HTML 元素加点小料,给 HTML 元素换个皮肤,让 HTML 元素动起来啥的。要干这些事的前提是要找对 HTML 元素,找错了就乱套了~~
/*
通过 ID 选择
查找页面上 id="header" 的第一个元素
比如:
<section id="header"></section>
<header id="header"></header>
只要是 ID 为 header 的元素,都能选择,但是只会找第一个
*/
const header = document.getElementById("header");
/*
通过类名选择(返回动态集合)
查找页面上 的所有元素
比如:
<button ></button>
*/
const buttons = document.getElementsByClassName("btn");
/*
通过标签名选择
与 getElementsByClassName 类似,只是选择页面上所有的 img 元素
*/
const images = document.getElementsByTagName("img");
/*
通过 CSS 选择器(静态集合)
此方法可以使用 CSS 选择器来获取页面上的元素
比如可以使用 .item:nth-child(3) 选择页面上 的第三个元素
*/
const firstButton = document.querySelector(".btn:first-child");
const allButtons = document.querySelectorAll(".btn");
复制代码
动态集合 vs 静态集合
顾名思义,动态集合就是会根据 HTML 内容变化而变化,而静态集合就是不管 HTML 怎么变,都是选择器方法执行的那一瞬间就确定了他的样子。
<ul >
<li >1</li>
<li >2</li>
<li >3</li>
<li >4</li>
<li >5</li>
</ul>
复制代码
节点关系
除了直接查找节点的方法外,还能通过获取到的节点关系属性,取到相对于的节点,比如:
parentNode 用于选择父节点。
childNodes 用于选择所有子节点,包括所有的子内容(比如:注释、空格、文本内容等)。
children 仅选择元素节点内容。
firstChild 选择第一个子内容,可以是注释、文本内容、换行符等。
lastChild 选择最后一个子内容,可以是注释、文本内容、换行符等。
firstElementChild 选择第一个元素节点。
lastElementChild 选择最后一个元素节点。
nextSibling 选择当前节点后一个内容,可以是注释、文本内容、换行符等。
previousSibling 选择当前节点前一个内容,可以是注释、文本内容、换行符等。
nextElementSibling 选择当前节点后一个元素节点。
previousElementSibling 选择当前节点前一个元素节点。
<ul >1122
<li >1</li>
<li >2</li>
321<li >3</li>123
<li >4</li>
<li >5</li>
</ul>
复制代码
写在最后
常用的 DOM 查找方法基本就这些,还有些不太常用的方法本文就不一一列举,有兴趣可以查看 MDN 文档 https://developer.mozilla.org/zh-CN/docs/Web/API/Element。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
Web
前端
门第
JavaScript
DOM
相关帖子
有没有比较简便的前端可以看到联调的时候真实URL的方法?
前端网页中粒子漂浮且与鼠标光标互动效果的实现
大学生挑战全网超详细web笔记02弹
Oracle RMAN物理备份Web系统
90%前端面试必问的12个JS核心,搞懂这些直接起飞!
web课堂笔记
前端如何防止用户重复提交表单?4 种可靠方案(附防坑指南)
JavaScript this绑定规则:告别踩坑指南!
为什么我建议前端基建有必要做 npm 仓库私有化
【JavaScript高级编程】拆解函数流水线 上
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
安全
有没有比较简便的前端可以看到联调的时候真实URL的方法?
0
210
府扔影
2026-03-11
业界
前端网页中粒子漂浮且与鼠标光标互动效果的实现
0
1002
荆邦
2026-03-13
业界
大学生挑战全网超详细web笔记02弹
0
173
损注
2026-03-17
业界
Oracle RMAN物理备份Web系统
0
278
古修蟑
2026-03-18
安全
90%前端面试必问的12个JS核心,搞懂这些直接起飞!
0
694
樊涵菡
2026-03-18
安全
web课堂笔记
0
953
计海龄
2026-03-23
代码
前端如何防止用户重复提交表单?4 种可靠方案(附防坑指南)
0
553
茹静曼
2026-03-24
安全
JavaScript this绑定规则:告别踩坑指南!
0
70
诈知
2026-03-24
业界
为什么我建议前端基建有必要做 npm 仓库私有化
0
492
滕佩杉
2026-03-30
业界
【JavaScript高级编程】拆解函数流水线 上
0
260
姥恫
2026-03-30
回复
(32)
粒浊
2025-11-8 11:00:19
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢,下载保存了
孟茹云
2025-12-5 04:30:23
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享,学习下。
类饲冰
2025-12-8 06:45:07
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
分享、互助 让互联网精神温暖你我
貊淀
2025-12-10 21:43:55
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
前排留名,哈哈哈
醋辛
2025-12-11 18:23:38
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢楼主提供!
甘子萱
2025-12-13 17:49:07
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
这个有用。
涂流如
2025-12-16 03:46:06
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
yyds。多谢分享
归筠溪
2026-1-14 06:05:26
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
喜欢鼓捣这些软件,现在用得少,谢谢分享!
祝娜娜
2026-1-16 14:36:33
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
懂技术并乐意极积无私分享的人越来越少。珍惜
泻缥
2026-1-17 23:50:03
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
过来提前占个楼
后仲舒
2026-1-19 16:02:04
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
感谢发布原创作品,程序园因你更精彩
存叭
2026-1-21 06:59:13
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
东西不错很实用谢谢分享
章绮云
2026-1-21 08:51:43
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
这个有用。
乳杂丫
2026-1-21 19:50:24
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
不错,里面软件多更新就更好了
湄圳啸
2026-1-22 11:48:02
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
鼓励转贴优秀软件安全工具和文档!
兮督
2026-1-24 11:30:32
回复
使用道具
举报
照妖镜
程序园永久vip申请,无限下载程序园所有程序/软件/数据/等
谢谢分享,试用一下
越蔓蔓
2026-1-26 04:03:40
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
分享、互助 让互联网精神温暖你我
轩辕娅童
2026-1-26 10:45:54
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
鼓励转贴优秀软件安全工具和文档!
袁勤
2026-2-1 21:00:55
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
过来提前占个楼
下一页 »
1
2
/ 2 页
下一页
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
签约作者
程序园优秀签约作者
发帖
厨浴
2026-2-1 21:00:55
关注
0
粉丝关注
21
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991125
anyue1937
9994892
kk14977
6845359
4
xiangqian
638210
5
神泱
9522
6
韶又彤
9916
7
宋子
9878
8
荪俗
9020
9
闰咄阅
9997
10
刎唇
9999
查看更多
今日好文热榜
580
Qt 技巧笔记(十四):QTableWidget 表格组
259
【JavaScript高级编程】拆解函数流水线 上
442
Claude 绝密模型泄露!Sora 关停、AI 工具
388
P10387 [蓝桥杯 2024 省 A] 训练士兵
110
电容是什么?一个“快充快放”的微型充电宝
943
做了一个网页天气可视化 2
694
Redis命令处理机制源码探究
722
读2025世界前沿技术发展报告27核力量
1
读2025世界前沿技术发展报告27核力量
2
读2025世界前沿技术发展报告27核力量
1
读2025世界前沿技术发展报告27核力量
1
读2025世界前沿技术发展报告27核力量
1
读2025世界前沿技术发展报告27核力量
1
Claude 绝密模型泄露!Sora 关停、AI 工具
1
做了一个网页天气可视化 2
1
做了一个网页天气可视化 2
1
Redis命令处理机制源码探究
1
【JavaScript高级编程】拆解函数流水线 上
1
Claude 绝密模型泄露!Sora 关停、AI 工具
1
Claude 绝密模型泄露!Sora 关停、AI 工具