JS querySelector方法的优点

1. 灵活性

支持所有 CSS 选择器

  • ID 选择器#id
    • 示例:document.querySelector('#myId')
    • 解释:选择 id 为 myId 的元素。
  • 类选择器.class
    • 示例:document.querySelector('.myClass')
    • 解释:选择具有 class 为 myClass 的元素。
  • 标签选择器tag
    • 示例:document.querySelector('div')
    • 解释:选择所有 <div> 元素。
  • 属性选择器[attribute]
    • 示例:document.querySelector('[href="https://example.com"]')
    • 解释:选择具有 href 属性值为 https://example.com 的元素。
  • 组合选择器.class1 .class2.class1 > .class2
    • 示例:document.querySelector('.container > .item')
    • 解释:选择 .container 元素内部的所有直接子元素 .item
  • 伪类选择器:hover:first-child
    • 示例:document.querySelector('a:hover')
    • 解释:选择当前处于悬停状态的 <a> 元素。
  • 伪元素选择器::before::after
    • 示例:document.querySelector('p::before')
    • 解释:选择 <p> 元素的 ::before 伪元素(通常用于样式,而不是脚本操作)。

组合选择器的灵活性

  • querySelector 支持复杂的组合选择器,这使得你可以精确地选择特定的元素。
    • 示例:document.querySelector('.container .item:nth-child(2)')
    • 解释:选择 .container 内部的第二个 .item 元素。

2. 简洁性

单一方法

  • 使用 querySelector 可以替代多个方法(如 getElementByIdgetElementsByClassNamegetElementsByTagName 等),使代码更加简洁。
    • 示例:
      // 使用 querySelector
      let elementById = document.querySelector('#myId');
      let elementByClass = document.querySelector('.myClass');
      let elementByTag = document.querySelector('div');// 对比使用多个方法
      let elementById = document.getElementById('myId');
      let elementByClass = document.getElementsByClassName('myClass')[0];
      let elementByTag = document.getElementsByTagName('div')[0];

代码简洁

  • querySelector 的语法简洁明了,易于阅读和理解。
    • 示例:
      // 使用 querySelector
      let firstItem = document.querySelector('.list .item:first-child');// 对比使用多个方法
      let listItems = document.getElementsByClassName('list')[0].getElementsByClassName('item');
      let firstItem = listItems[0];

3. 链式调用

子树查询

  • 可以在一个特定的元素内部使用 querySelector,从而限制搜索范围,提高性能。
    • 示例:
      let container = document.getElementById('container');
      let item = container.querySelector('.item');
    • 解释:在 container 元素内部查找具有 class 为 item 的第一个元素。

4. 动态选择

实时更新

  • querySelector 每次调用时都会重新解析选择器并查找匹配的元素,即使 DOM 发生了变化,也能正确返回最新的匹配元素。
    • 示例:
      let container = document.getElementById('container');
      let item = container.querySelector('.item');
      console.log(item); // 输出初始匹配的 .item 元素// 动态添加新的 .item 元素
      let newItem = document.createElement('div');
      newItem.className = 'item';
      container.appendChild(newItem);// 再次查询
      let newItemElement = container.querySelector('.item');
      console.log(newItemElement); // 输出新添加的 .item 元素

5. 兼容性

广泛支持

  • 被所有现代浏览器支持,包括 IE8+。
    • 在 IE8 中,只支持基本的选择器(如 ID 选择器、类选择器和标签选择器),不支持伪类和伪元素选择器。
    • 示例:
      // 在 IE8+ 中支持
      let elementById = document.querySelector('#myId');
      let elementByClass = document.querySelector('.myClass');
      let elementByTag = document.querySelector('div');// 在 IE8 中不支持
      let elementByPseudoClass = document.querySelector('a:hover'); // 不支持

6. 性能优化

缓存机制

  • 现代浏览器通常会有优化机制,如缓存解析结果,以提高多次调用的性能。
    • 示例:
      function updateElement() {let element = document.querySelector('.item');element.textContent = 'Updated Text';
      }// 多次调用 updateElement
      for (let i = 0; i < 100; i++) {updateElement();
      }

局部搜索

  • 通过在特定元素上调用 querySelector 来限制搜索范围,从而提高性能。
    • 示例:
      let container = document.getElementById('container');
      let item = container.querySelector('.item'); // 仅在 container 内部搜索

7. 易于扩展

组合使用

  • 可以与其他 DOM 操作方法结合使用,构建更复杂的逻辑。
    • 示例:
      let elements = document.querySelectorAll('.item');
      elements.forEach(function(element) {element.style.color = 'blue'; // 修改每个元素的样式
      });// 使用箭头函数简化
      document.querySelectorAll('.item').forEach(element => {element.style.color = 'blue';
      });

8. 避免命名冲突

唯一性要求低

  • 不像 getElementById 那样要求 id 必须唯一,querySelector 可以使用更宽松的选择器来选择元素,避免因 id 冲突而导致的问题。
    • 示例:
      let elements = document.querySelectorAll('.myClass');
      if (elements.length > 0) {console.log('Found', elements.length, 'elements with class "myClass"');
      }

实际应用场景

1. 表单验证

  • 使用 querySelector 可以轻松选择表单中的特定输入字段并进行验证。
    • 示例:
      <form id="myForm"><input type="text" name="username" class="input-field" required><input type="password" name="password" class="input-field" required><button type="submit">Submit</button>
      </form><script>document.getElementById('myForm').addEventListener('submit', function(event) {event.preventDefault();let username = document.querySelector('[name="username"]');let password = document.querySelector('[name="password"]');if (!username.value || !password.value) {alert('Please fill in all fields.');return;}console.log('Form submitted successfully!');});
      </script>

2. 动态内容生成

  • 使用 querySelector 可以在动态生成的内容中选择特定的元素。
    • 示例:
      <div id="container"></div><script>function addItem(name, price) {let item = document.createElement('div');item.className = 'item';item.innerHTML = `<span class="name">${name}</span> - <span class="price">${price}</span>`;document.getElementById('container').appendChild(item);}addItem('Apple', '$1.00');addItem('Banana', '$0.50');// 选择第一个商品的价格let firstPrice = document.querySelector('.item .price');console.log(firstPrice.textContent); // 输出 "$1.00"
      </script>

3. 响应式设计

  • 使用 querySelector 可以根据屏幕尺寸选择特定的元素并进行样式调整。
    • 示例:
      <div class="content"><p class="header">Welcome to Our Website</p><p class="body">This is a sample content.</p>
      </div><script>window.addEventListener('resize', function() {let header = document.querySelector('.content .header');let body = document.querySelector('.content .body');if (window.innerWidth < 600) {header.style.fontSize = '20px';body.style.fontSize = '14px';} else {header.style.fontSize = '24px';body.style.fontSize = '16px';}});
      </script>

总结

querySelector 的主要优点在于其灵活性、简洁性、链式调用能力、动态选择特性、广泛的支持和性能优化。这些优点使其成为现代前端开发中选择 DOM 元素的首选方法之一。无论是在简单的项目中还是在复杂的 Web 应用中,querySelector 都能提供强大的功能和高效的性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/483575.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

03-13、SpringCloud Alibaba第十三章,升级篇,服务降级、熔断和限流Sentinel

SpringCloud Alibaba第十三章&#xff0c;升级篇&#xff0c;服务降级、熔断和限流Sentinel 一、Sentinel概述 1、Sentinel是什么 随着微服务的流行&#xff0c;服务和服务之间的稳定性变得越来越重要。Sentinel 以流量为切入点&#xff0c;从流量控制、熔断降级、系统负载保…

基于vite6+ vue3 + electron@33 实现的 局域网内互传文件的桌面软件

目录 项目介绍项目部分截图介绍下基础项目搭建先搭建一个vite 前端项目 再安装 electron 相关依赖依赖安装失败解决方案修改 vite配置文件和 ts 配置文件修改packjsonts相关配置项目结构介绍 项目介绍 前端 基于 vue3 ts windicss 后端 就是node 层 项目地址&#xff1a; h…

安装MySQL 5.7 亲测有效

前言&#xff1a;本文是笔者在安装MySQL5.7时根据另一位博主大大的安装教程基础上做了一些修改而成 首先在这里表示对博主大大的感谢 下面附博主大大地址 下面的步骤言简意赅 跟着做就不会出错 希望各位读者耐下心来 慢慢解决安装中出现的问题~MySQL 5.7 安装教程&#xff08;全…

CSS函数

目录 一、背景 二、函数的概念 1. var()函数 2、calc()函数 三、总结 一、背景 今天我们就来说一说&#xff0c;常用的两个css自定义属性&#xff0c;也称为css函数。本文中就成为css函数。先来看一下官方对其的定义。 自定义属性&#xff08;有时候也被称作CSS 变量或者级…

6.824/6.5840 Lab 1: MapReduce

宁静的夏天 天空中繁星点点 心里头有些思念 思念着你的脸 ——宁夏 完整代码见&#xff1a; https://github.com/SnowLegend-star/6.824 由于这个lab整体难度实在不小&#xff0c;故考虑再三还是决定留下代码仅供参考 6.824的强度早有耳闻&#xff0c;我终于也是到了挑战这座高…

MongoDB集群分片安装部署手册

文章目录 一、集群规划1.1 集群安装规划1.2 端口规划1.3 目录创建 二、mongodb安装&#xff08;三台均需要操作&#xff09;2.1 下载、解压2.2 配置环境变量 三、mongodb组件配置3.1 配置config server的副本集3.1.1 config配置文件3.1.2 config server启动3.1.3 初始化config …

一种多功能调试工具设计方案开源

一种多功能调试工具设计方案开源 设计初衷设计方案具体实现HUB芯片采用沁恒微CH339W。TF卡功能网口功能SPI功能IIC功能JTAG功能下行USB接口 安路FPGA烧录器功能Xilinx FPGA烧录器功能Jlink OB功能串口功能RS232串口RS485和RS422串口自适应接口 CAN功能烧录器功能 目前进度后续计…

三维测量与建模笔记 - 5.3 光束法平差(Bundle Adjustment)

此篇笔记尚未理解&#xff0c;先做笔记。 如上图&#xff0c;在不同位姿下对同一个物体采集到了一系列图像&#xff0c; 例子中有四张图片。物体上某点M&#xff0c;在四幅图像上都能找到其观测点。 上式中的f函数是对使用做投影得到的估计点位置。求解这个方程有几种方法&…

力扣hot100道【贪心算法后续解题方法心得】(三)

力扣hot100道【贪心算法后续解题方法心得】 十四、贪心算法关键解题思路1、买卖股票的最佳时机2、跳跃游戏3、跳跃游戏 | |4、划分字母区间 十五、动态规划什么是动态规划&#xff1f;关键解题思路和步骤1、打家劫舍2、01背包问题3、完全平方式4、零钱兑换5、单词拆分6、最长递…

ElasticSearch学习篇19_《检索技术核心20讲》搜推广系统设计思想

目录 主要是包含搜推广系统的基本模块简单介绍&#xff0c;另有一些流程、设计思想的分析。 搜索引擎 基本模块检索流程 查询分析查询纠错 广告引擎 基于标签倒排索引召回基于向量ANN检索召回打分机制&#xff1a;非精确打分精准深度学习模型打分索引精简&#xff1a;必要的…

Ambrus 游戏工作室将应对气候变暖与游戏变现完美结合

当 Ambrus Studio 创始人兼 CEO Johnson Yeh 计划打造他称之为“第一款伟大的 Web3 游戏”时&#xff0c;他设立了两个关键目标&#xff1a;游戏需要在传统大型工作室忽视的市场中盈利&#xff0c;以及它需要具备超越娱乐的意义。 在 Sui 的帮助下&#xff0c;Johnson 和他的团…

KAN-Transfomer——基于新型神经网络KAN的时间序列预测

1.数据集介绍 ETT(电变压器温度)&#xff1a;由两个小时级数据集&#xff08;ETTh&#xff09;和两个 15 分钟级数据集&#xff08;ETTm&#xff09;组成。它们中的每一个都包含 2016 年 7 月至 2018 年 7 月的七种石油和电力变压器的负载特征。 traffic(交通) &#xff1a;描…

UEFI Spec 学习笔记---3 - Boot Manager(3)

3.2 Boot Manager Policy Protocol EFI_BOOT_MANAGER_POLICY_PROTOCOL----EFI应用程序使用该协议请求UEFI引导管理器使用平台策略连接设备。 typedef struct _EFI_BOOT_MANAGER_POLICY_PROTOCOL EFI_BOOT_MANAGER_POLICY_PROTOCOL; struct _EFI_BOOT_MANAGER_POLICY_PROTOCOL…

wordpress网站首页底部栏显示网站备案信息

一、页脚文件footer.php 例如&#xff0c;wordpress主题使用的是simple-life主题&#xff0c;服务器IP为192.168.68.89,在wordpress主题文件中有个页脚文件footer.php&#xff0c;这是一个包含网站页脚代码的文件。 footer.php 路径如下&#xff1a; /www/wwwroot/192.168.68…

QT实战-qt各种菜单样式实现

本文主要介绍了qt普通菜单样式、带选中样式、带子菜单样式、超过一屏幕菜单样式、自定义带有滚动条的菜单样式&#xff0c; 先上图如下&#xff1a; 1.普通菜单样式 代码&#xff1a; m_pmenu new QMenu(this);m_pmenu->setObjectName("quoteListMenu"); qss文…

数据结构实训——查找

声明&#xff1a; 以下是我们学校在学习数据结构时进行的实训&#xff0c;如涉及侵权马上删除文章 声明&#xff1a;本文主要用作技术分享&#xff0c;所有内容仅供参考。任何使用或依赖于本文信息所造成的法律后果均与本人无关。请读者自行判断风险&#xff0c;并遵循相关法…

指针(上)

目录 内存和地址 指针变量和地址 取地址&#xff08;&&#xff09; 解引用&#xff08;*&#xff09; 大小 类型 意义 const修饰 修饰变量 修饰指针 指针运算 指针- 整数 指针-指针 指针的关系运算 野指针 概念 成因 避免 assert断言 指针的使用 strl…

13TB的StarRocks大数据库迁移过程

公司有一套StarRocks的大数据库在大股东的腾讯云环境中&#xff0c;通过腾讯云的对等连接打通&#xff0c;通过dolphinscheduler调度datax离线抽取数据和SQL计算汇总&#xff0c;还有在大股东的特有的Flink集群环境&#xff0c;该环境开发了flink开发程序包部署&#xff0c;实时…

ARP表、MAC表、路由表的区别和各自作用

文章目录 ARP表、MAC表、路由表的区别和各自作用同一网络内:ARP表request - 请求reply - 响应 MAC地址在同一网络内,交换机如何工作? 不同网络路由表不同网络通信流程PC1到路由器路由器到PC2流程图 简短总结 ARP表、MAC表、路由表的区别和各自作用 拓扑图如下: 同一网络内:…

第七课 Unity编辑器创建的资源优化_UI篇(UGUI)

上期我们学习了简单的Scene优化&#xff0c;接下来我们继续编辑器创建资源的UGUI优化 UI篇&#xff08;UGUI&#xff09; 优化UGUI应从哪些方面入手&#xff1f; 可以从CPU和GPU两方面考虑&#xff0c;CPU方面&#xff0c;避免触发或减少Canvas的Rebuild和Rebatch&#xff0c…