0

0

JavaScript:根据属性值查找元素并修改其类名

DDD

DDD

发布时间:2025-11-03 11:59:01

|

631人浏览过

|

来源于php中文网

原创

javascript:根据属性值查找元素并修改其类名

本文档将介绍如何使用 JavaScript 查找具有特定属性值的 HTML 元素,并动态地修改其 CSS 类名。我们将通过一个实际示例,演示如何根据按钮点击事件传递的 ID 值,查找具有相应 `data-dselect-value` 属性的元素,并为其添加 `active` 类。

使用 document.querySelector 查找元素

JavaScript 提供了多种方法来查找 HTML 元素,其中 document.querySelector 方法是最灵活和常用的方法之一。它允许我们使用 CSS 选择器来查找元素。

在我们的示例中,我们需要查找 data-dselect-value 属性值等于按钮点击事件传递的 ID 值的元素。我们可以使用属性选择器 [attribute="value"] 来实现。

以下是实现该功能的 JavaScript 代码:

立即学习Java免费学习笔记(深入)”;

HaloTool
HaloTool

AI工具在线集合网站

下载
function myFunc(clicked_id){
    var elem = document.querySelector('[data-dselect-value="'+clicked_id+'"]');
    elem.classList.add('active');   
};

代码解释:

  1. function myFunc(clicked_id){ ... }: 定义一个名为 myFunc 的函数,该函数接受一个参数 clicked_id,该参数表示被点击按钮的 ID 值。
  2. document.querySelector('[data-dselect-value="'+clicked_id+'"]'): 使用 document.querySelector 方法查找具有 data-dselect-value 属性且其值等于 clicked_id 的元素。 [data-dselect-value="'+clicked_id+'"] 是一个 CSS 属性选择器,它选择具有指定属性和值的元素。
  3. elem.classList.add('active'): 如果找到匹配的元素,则使用 classList.add('active') 方法将 active 类添加到该元素的类列表中。

HTML 示例

为了更好地理解上述代码,我们提供一个 HTML 示例:

<div class="dropdown-menu">
    <div class="d-flex flex-column">
        <input onkeydown="return event.key !== 'Enter'" onkeyup="dselectSearch(event, this, 'dselect-wrapper', 'form-select', false)" type="text" class="form-control" placeholder="Search" autofocus="">
        <div class="dselect-items" style="max-height:360px;overflow:auto">
          <button class="dropdown-item active" data-dselect-value="1109" type="button" onclick="dselectUpdate(this, 'dselect-wrapper', 'form-select')">Charles</button>
          <button class="dropdown-item" data-dselect-value="1108" type="button" onclick="dselectUpdate(this, 'dselect-wrapper', 'form-select')">Fred</button>
          <button class="dropdown-item" data-dselect-value="1107" type="button" onclick="dselectUpdate(this, 'dselect-wrapper', 'form-select')">Lionel</button>
          <button class="dropdown-item" data-dselect-value="1106" type="button" onclick="dselectUpdate(this, 'dselect-wrapper', 'form-select')">Robert</button>
          <button class="dropdown-item" data-dselect-value="1105" type="button" onclick="dselectUpdate(this, 'dselect-wrapper', 'form-select')">Mike</button>
        </div>
        <div class="dselect-no-results d-none">No results found</div>
    </div>
</div>

<button onclick="myFunc(this.id)"  id="1106">Select client</button>

在这个例子中,当点击 ID 为 "1106" 的按钮时,myFunc 函数会被调用,并将 "1106" 作为 clicked_id 传递给函数。 document.querySelector 将查找 data-dselect-value 属性值为 "1106" 的按钮元素,并为其添加 active 类。

注意事项

  • 确保 clicked_id 的值与 HTML 元素中的 data-dselect-value 属性值完全匹配。
  • 如果页面上有多个具有相同 data-dselect-value 属性值的元素,document.querySelector 只会返回第一个匹配的元素。 如果需要选择所有匹配的元素,可以使用 document.querySelectorAll。
  • classList.add() 方法用于添加类名。 如果需要删除类名,可以使用 classList.remove() 方法。 如果需要切换类名,可以使用 classList.toggle() 方法。

总结

本文介绍了如何使用 JavaScript 根据属性值查找 HTML 元素,并动态地修改其 CSS 类名。 document.querySelector 方法是一个强大的工具,可以帮助我们轻松地查找和操作 HTML 元素。 理解并掌握这些技术,可以帮助我们构建更加动态和交互性强的 Web 应用程序。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

500

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

167

2023.10.07

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

2

2026.03.18

Java Spring Security权限控制与认证机制实战
Java Spring Security权限控制与认证机制实战

本专题围绕 Java 后端安全体系建设展开,重点讲解 Spring Security 在权限控制与认证机制中的应用实践。内容涵盖用户认证流程、权限模型设计、JWT 鉴权方案、OAuth2 集成以及接口安全防护策略。通过实际项目案例,帮助开发者构建安全可靠的后端认证体系,提升系统安全性与可扩展能力。

0

2026.03.18

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

110

2026.03.17

多环境下的 Nginx 安装、结构与运维实战
多环境下的 Nginx 安装、结构与运维实战

本专题聚焦多环境下Nginx实战,详解开发、测试及生产环境的差异化安装策略与目录结构规划。深入剖析配置模块化设计、灰度发布流程及跨环境同步机制。结合监控告警、故障排查与自动化运维工具,提供全链路管理方案,助力团队构建灵活、高可用的Nginx服务体系,从容应对复杂业务场景挑战。

13

2026.03.17

PS 批量添加图片
PS 批量添加图片

本专题整合了PS批量添加图片教程合集,阅读专题下面的文章了解更多详细操作。

10

2026.03.17

Nginx 基础架构:从安装配置到系统化管理
Nginx 基础架构:从安装配置到系统化管理

本专题深入解析Nginx基础架构,涵盖从源码编译与包管理安装,到核心配置文件优化及虚拟主机部署。进一步探讨日志轮转、性能调优、高可用集群构建及自动化运维策略,助力管理员实现从单一服务搭建到企业级系统化管理的全面升级,确保Web服务高效、稳定运行。

7

2026.03.17

mulerun骡子快跑入口地址汇总
mulerun骡子快跑入口地址汇总

本专题整合了mulerun入口地址合集,阅读专题下面的文章了解更多详细内容。

216

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 1.0万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.7万人学习

CSS教程
CSS教程

共754课时 | 44.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号