news 2026/4/3 4:14:35

JavaScript DOM 原生部分(一):获取DOM

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
JavaScript DOM 原生部分(一):获取DOM

文章目录

  • 一.根据 ID 获取( getElementById )
  • 二.根据类名获取( getElementsByClassName )
  • 三.根据标签名获取( getElementsByTagName )
  • 四.根据选择器获取( querySelector / querySelectorAll )
    • 1.querySelector
    • 2.querySelectorAll
  • 五.获取表单元素( getElementsByName )
  • 六.获取特殊元素( 文档 / body / 头部 )
  • 注意事项
  • 总结

原生方法无需依赖任何库,是最基础且高效的方式,主要通过document对象提供的 API 实现.

一.根据 ID 获取( getElementById )

  • 作用: 通过元素的id属性获取唯一的 DOM 元素(因为id在文档中应唯一).
  • 语法:
    document.getElementById(id值)
  • 返回值: 匹配的 DOM 元素对象,若不存在则返回null.
// HTML: <div id="box">Hello</div>constbox=document.getElementById('box');console.log(box);// <div id="box">Hello</div>

二.根据类名获取( getElementsByClassName )

  • 作用: 通过元素的class属性获取所有匹配的元素集合(HTMLCollection,类数组对象).
  • 语法:
    document.getElementsByClassName(类名)
  • 返回值: 包含所有匹配元素的 HTMLCollection,若不存在则返回空集合.
// HTML: <div class="item">1</div><div class="item">2</div>constitems=document.getElementsByClassName('item');console.log(items);// HTMLCollection(2) [div.item, div.item]console.log(items[0]);// 取第一个元素: <div class="item">1</div>

三.根据标签名获取( getElementsByTagName )

  • 作用: 通过元素的标签名(如divpul)获取所有匹配的元素集合(HTMLCollection).
  • 语法:
    document.getElementsByTagName(标签名)
  • 返回值: 包含所有匹配元素的 HTMLCollection,若不存在则返回空集合.
// HTML: <p>文本1</p><p>文本2</p>constparas=document.getElementsByTagName('p');console.log(paras.length);// 2

四.根据选择器获取( querySelector / querySelectorAll )

这是最灵活的方式,支持 CSS 选择器语法,是现代开发中最常用的方法.

1.querySelector

  • 作用: 获取第一个匹配 CSS 选择器的 DOM 元素.
  • 语法:
    document.querySelector(选择器)
  • 返回值: 第一个匹配的元素对象,若不存在则返回null.
// HTML: <div class="item">1</div><div class="item">2</div>constfirstItem=document.querySelector('.item');// 类选择器constbox=document.querySelector('#box');// ID 选择器constp=document.querySelector('ul li: first-child');// 复杂 CSS 选择器

2.querySelectorAll

  • 作用: 获取所有匹配 CSS 选择器的元素集合(NodeList,类数组对象).
  • 语法:
    document.querySelectorAll(选择器)
  • 返回值: 包含所有匹配元素的 NodeList,若不存在则返回空集合.
// HTML: <div class="item">1</div><div class="item">2</div>constallItems=document.querySelectorAll('.item');console.log(allItems);// NodeList(2) [div.item, div.item]// 可通过 forEach 遍历(NodeList 支持 forEach,HTMLCollection 不支持)allItems.forEach((item)=>console.log(item));

五.获取表单元素( getElementsByName )

  • 作用: 通过元素的name属性获取元素(主要用于表单元素,如inputselect).
  • 语法:
    document.getElementsByName(name值)
  • 返回值: NodeList 集合.
// HTML: <input type="text" name="username">constusername=document.getElementsByName('username')[0];// 取第一个匹配元素

六.获取特殊元素( 文档 / body / 头部 )

// 获取 html 根元素consthtml=document.documentElement;// 获取 body 元素constbody=document.body;// 获取 head 元素consthead=document.head;

注意事项

  1. 获取时机: 必须等待 DOM 加载完成后再获取元素,否则可能返回null.

    • 解决方式:
      • 将脚本放在<body>底部;
      • 使用DOMContentLoaded事件:
        document.addEventListener('DOMContentLoaded',function(){// 在这里获取元素});
  2. 集合类型:

    • getElementsByClassName/getElementsByTagName返回HTMLCollection(动态集合,DOM 变化会实时更新);
    • querySelectorAll/getElementsByName返回NodeList(静态集合,DOM 变化不会更新);
    • 两者都是类数组对象,可通过Array.from()或扩展运算符转为真正的数组:
      constitems=document.querySelectorAll('.item');constitemsArr=Array.from(items);// 转为数组
  3. 性能:getElementById是最快的获取方式(因为 ID 唯一),其次是querySelector,复杂选择器的性能略低,但在现代浏览器中差异可忽略.

总结

  • 原生 JavaScript 中,querySelector/querySelectorAll因支持 CSS 选择器而最常用,灵活性最高;
  • 简单场景(如按 ID 获取)用getElementById更高效;
  • 框架中优先使用其提供的选择器语法,简化代码.
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/25 4:10:04

AI正在加剧技术求职者与雇主之间的不信任

AI已成为科技招聘的主流工具&#xff0c;极大提升了效率&#xff0c;但也引发严重的信任危机。调查显示&#xff0c;仅14%的科技求职者信任完全由AI主导的招聘流程&#xff0c;多数人担心简历只被算法筛选、能力被关键词取代。AI正在简化人们的求职流程&#xff0c;但随着越来越…

作者头像 李华
网站建设 2026/3/28 17:58:20

Python编程语言面试问题三

Python列表面试问题列表的 del&#xff08;&#xff09; 和 remove&#xff08;&#xff09; 方法有什么区别&#xff1f;del&#xff08;&#xff09; 和 remove&#xff08;&#xff09; 方法都用于从列表中移除元素。del&#xff08;&#xff09; 用于删除指定索引值处的元素…

作者头像 李华
网站建设 2026/3/19 19:43:50

【Java】线程池源码解析

hreadPoolExecutor#首先是ThreadPoolExecutor()里面可以看到线程池核心参数public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue<Runnable> workQueue,ThreadFactory threadFactory,RejectedExecutionHandl…

作者头像 李华
网站建设 2026/3/29 12:31:44

8个关于YashanDB的常见误区与真相

在当前数据驱动的业务环境中&#xff0c;数据库系统作为核心信息基础设施&#xff0c;其性能瓶颈、数据一致性保障及高可用性实现等挑战日益突显。YashanDB作为一款支持多种部署形态的先进数据库系统&#xff0c;集成了行列混合存储、分布式和共享集群架构等多项技术优势&#…

作者头像 李华
网站建设 2026/3/31 6:52:45

数据上新预告 | 中国各省市官方媒体微信公众号数据

一、数据简介CnOpenData即将推出「中国各省市官方媒体微信公众号数据库」。本数据集通过系统采集与整理全国31个省份的省委机关报及其所属的三百个地级市的市委机关报在微信公众号上公开发布的文章&#xff0c;形成一套全域覆盖、系统连续、可深度分析的数据资源&#xff0c;为…

作者头像 李华
网站建设 2026/3/29 18:12:23

Pycharm错误:JetBrains AI URL resolution failure

Pycharm 版本2025.2.4问题Pycharm AI Assistant 找不到输入框&#xff0c;提示&#xff1a;Error: 451 Exception during request to https://api.jetbrains.ai/ping with code 451, id: Unknown。20251125_JetBrains AI URL resolution failure原因分析HTTP 451 状态码的意思是…

作者头像 李华