使用 JavaScript 通过 ID 匹配不同父元素中的元素(鼠标悬停时)

使用 javascript 通过 id 匹配不同父元素中的元素(鼠标悬停时)

本文介绍如何使用 JavaScript 实现当鼠标悬停在一个 `div.first` 中的 `li` 元素上时,为 `div.second` 中具有相同 ID 的 `li` 元素添加 `.active` 类。该方案适用于 ID 动态生成且事先未知的情况,并提供详细的 JavaScript 代码示例和 CSS 样式,方便读者理解和应用。

在 Web 开发中,有时我们需要实现一种交互效果:当鼠标悬停在一个区域的元素上时,另一个区域的对应元素也发生变化。本文将介绍如何使用 JavaScript 实现这一功能,具体来说,当鼠标悬停在一个 div.first 中的 li 元素上时,为 div.second 中具有相同 ID 的 li 元素添加 .active 类。

实现原理

核心思想是利用 JavaScript 监听 div.first 中所有 li 元素的 mouseover 和 mouseout 事件。当 mouseover 事件触发时,获取当前 li 元素的 ID,然后在 div.second 中查找具有相同 ID 的 li 元素,并添加 .active 类。当 mouseout 事件触发时,移除 .active 类。

代码实现

以下是完整的 JavaScript 代码实现:

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

document.querySelectorAll(".first ul li").forEach(li => {  li.addEventListener("mouseover", e => {    document.querySelectorAll(`#${e.target.id}`)[1].classList.add("active");  });  li.addEventListener("mouseout", e => {    document.querySelectorAll(`#${e.target.id}`)[1].classList.remove("active");  });});

这段代码首先使用 querySelectorAll 方法获取所有位于 .first 类下的 ul 元素中的 li 元素。然后,使用 forEach 方法遍历这些 li 元素,并为每个元素添加 mouseover 和 mouseout 事件监听器。

在 mouseover 事件监听器中,e.target.id 获取当前鼠标悬停的 li 元素的 ID。然后,使用 querySelectorAll(#${e.target.id}) 查找具有相同 ID 的所有元素。由于我们需要操作的是 div.second 中的元素,因此我们使用 [1] 来获取第二个匹配的元素(第一个匹配的元素是 div.first 中的 li 元素本身)。最后,使用 classList.add(“active”) 为该元素添加 .active 类。

mouseout 事件监听器中的逻辑类似,只是将 classList.add(“active”) 替换为 classList.remove(“active”),用于移除 .active 类。

HTML 结构

以下是 HTML 结构示例:

  • Lorem
  • Ipsum
  • Dolor
  • Lorem
  • Ipsum
  • Dolor

CSS 样式

为了使 .active 类生效,我们需要定义相应的 CSS 样式:

.active {  background: #CCC;}

这段 CSS 代码会将具有 .active 类的元素的背景色设置为灰色。

注意事项

ID 唯一性: 此方法依赖于 ID 的唯一性。确保页面上所有 li 元素的 ID 都是唯一的,否则可能会导致意外的结果。性能优化: 如果页面上有大量的 li 元素,频繁的 querySelectorAll 操作可能会影响性能。可以考虑使用事件委托等技术进行优化。适用场景: 此方法适用于 ID 动态生成且事先未知的情况。如果 ID 是静态的,可以使用 CSS :hover 伪类和相邻兄弟选择器等方法来实现类似的效果,性能更高。

总结

本文介绍了如何使用 JavaScript 实现当鼠标悬停在一个 div.first 中的 li 元素上时,为 div.second 中具有相同 ID 的 li 元素添加 .active 类。该方案适用于 ID 动态生成且事先未知的情况,并提供了详细的代码示例和注意事项。希望本文能够帮助读者更好地理解和应用 JavaScript 技术。

以上就是使用 JavaScript 通过 ID 匹配不同父元素中的元素(鼠标悬停时)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1585775.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 01:57:39
下一篇 2025年12月23日 01:57:53

相关推荐

  • 前端开发:平滑禁用页面滚动,告别 overflow:hidden 的视觉跳动

    本文探讨了在使用 `overflow:hidden` 禁用页面滚动时可能出现的页面抖动问题。针对这一常见痛点,教程提供了两种优雅的替代方案:通过 javascript 事件监听器阻止滚动事件,以及利用 css `touch-action: none` 属性。这些方法能有效避免滚动条移除导致的布局偏移…

    好文分享 2025年12月23日
    000
  • CSS Flexbox实现导航栏列表项的水平居右与垂直居中

    本教程详细介绍了如何利用CSS Flexbox布局高效地实现导航栏中列表项的水平居右对齐和垂直居中。通过移除传统布局中的绝对定位和固定高度,我们将构建一个响应式且结构清晰的导航菜单,确保在不同屏幕尺寸下都能保持良好的视觉效果和布局稳定性。 导航栏列表项对齐挑战 在网页开发中,导航栏是用户界面的核心组…

    2025年12月23日
    000
  • HTML标题标签使用教程_HTML h1-h6标题标签层级使用指南

    h1到h6标签用于构建网页的层级结构,h1为最高级主标题,一般每页仅用一次,h2至h6逐级表示子章节;应按逻辑顺序使用,避免跳级,确保语义清晰。正确使用有助于搜索引擎理解页面重点,提升SEO效果,同时方便屏幕阅读器用户导航,增强可访问性。常见错误包括滥用h1、跳级使用或仅为了样式而使用标题标签,应通…

    2025年12月23日
    000
  • 使用JavaScript实现无关元素悬停时改变目标元素亮度

    本文详细介绍了如何利用javascript的事件监听器和css的`filter`属性,实现在网页中一个元素(触发器)被鼠标悬停时,改变另一个不相关的元素(目标)的亮度。教程涵盖了基本的html结构、javascript事件处理代码(包括鼠标进入和离开事件),以及通过css `transition` …

    2025年12月23日
    000
  • HTML表格标题怎么设置_HTML表格caption标题元素详解

    使用caption元素可为HTML表格添加标题,它必须作为table内的首个子元素,提升语义化与可访问性,默认居中显示于表上方,支持通过CSS调整样式,每个表格仅能有一个caption,应简洁明了。 在HTML中,为表格设置标题应使用 caption 元素。它专门用于定义表格的标题或说明,通常显示在…

    2025年12月23日
    000
  • Vuetify v-data-table 上下同时显示水平滚动条的实现方法

    本文介绍了如何在 Vuetify 的 `v-data-table` 组件的顶部和底部同时显示水平滚动条。核心思路是利用两个 `div` 元素,一个用于模拟滚动条,另一个包含实际内容,并通过 JavaScript 将它们的滚动行为同步,从而实现上下滚动条联动效果。提供了原生 JavaScript 和 …

    2025年12月23日
    000
  • 掌握React中动态属性值与受控组件的实现

    本文深入探讨了在react组件中如何动态引用一个属性的值到另一个属性,以及如何通过状态管理实现组件的交互性。我们将学习如何利用`usestate` hook来管理组件内部状态,从而使属性值保持同步并响应变化,最终构建出可控且功能丰富的react组件。 在React开发中,我们经常需要在一个组件的多个…

    2025年12月23日
    000
  • 使用 JavaScript 获取 Trivia 游戏中按钮索引并校验答案

    本文旨在帮助开发者解决 Trivia 游戏中如何获取被点击按钮的索引,并将其与正确答案进行比较的问题。通过监听按钮的点击事件,利用事件对象获取被点击按钮的ID,从而实现对用户选择答案的校验。本文将提供详细的代码示例和步骤,帮助你轻松解决这个问题。 获取按钮索引并校验答案 在 Trivia 游戏中,通…

    2025年12月23日
    000
  • 使用条件运算符高效格式化时间字符串

    本文介绍了如何使用 JavaScript 中的条件运算符(三元运算符)来高效地格式化时间字符串,避免使用大量的 `if` 语句,使代码更简洁易懂。通过示例代码和详细解释,帮助开发者掌握这种常用的编程技巧,提升代码质量。 在 JavaScript 中,格式化时间字符串,例如将 9:7 显示为 09:0…

    2025年12月23日
    000
  • 解决CSS :hover 伪类失效问题:常见语法错误与调试技巧

    本文探讨了css `:hover` 伪类失效的常见原因,特别是选择器语法错误,并提供了一个实际案例的解决方案。通过分析html和css代码,我们强调了正确使用伪类选择器 `#id:hover` 的重要性,以确保元素在鼠标悬停时能正确应用样式,同时提供了调试技巧和注意事项,帮助开发者避免类似问题。 理…

    2025年12月23日
    000
  • CSS布局:如何防止旋转图片溢出其父div

    当在css中使用`transform: rotate()`结合`position: absolute`对图片进行旋转时,图片可能会溢出其父容器并覆盖其他元素。本文将详细解释这一现象的原因,并提供一种简洁有效的解决方案:通过在父容器上应用`overflow: hidden`属性来裁剪溢出内容,确保布局…

    2025年12月23日
    000
  • 优化R Markdown中Plotly图表的离线依赖管理以减小HTML文件大小

    本文详细介绍了如何在r markdown中配置plotly图表,以实现`partial_bundle`功能的离线运行并有效减小html文件体积。核心方法是通过手动管理plotly的javascript依赖,将其从在线cdn或临时文件路径转移至本地存储,并更新图表对象的依赖引用。这确保了即使在无网络环…

    2025年12月23日
    000
  • HTML视频加载失败应该怎么办_HTML视频onerror事件处理错误的方法

    视频加载失败时可通过onerror事件捕获并处理,如显示备用封面、提示信息或切换备用源,结合多格式支持与路径检查可有效提升兼容性与用户体验。 当HTML中的视频加载失败时,可以通过onerror事件来捕获问题并给出反馈或尝试恢复。这不仅能提升用户体验,还能帮助开发者排查资源加载问题。 监听视频加载错…

    2025年12月23日
    000
  • html函数如何实现标签页功能 html函数radio按钮的隐藏与联动

    使用隐藏radio按钮和CSS :checked伪类实现标签页切换,通过label触发radio选中状态,利用兄弟选择器控制对应内容显示,结构需同父容器且顺序正确,可纯CSS完成无需JavaScript。 要实现标签页功能,并通过隐藏的 radio 按钮进行联动控制,不需要 JavaScript 函…

    2025年12月23日
    000
  • 如何用HTML在线制作投票系统_HTML在线投票系统制作与防作弊方案

    答案:制作在线投票系统需结合HTML%ignore_a_1%与后端技术,通过PHP和数据库处理投票数据,并采用IP限制、验证码、登录验证等措施防作弊,确保投票唯一性和安全性。 制作一个简单的HTML在线投票系统并不复杂,但要实现防作弊功能,需要结合后端技术和一些策略。纯HTML只能做静态页面展示,真…

    2025年12月23日
    000
  • 如何在HTML中插入条件显示内容_HTML JavaScript条件渲染与CSS显示控制

    核心是通过JavaScript判断条件并操作DOM。常用方法包括:直接修改元素style.display属性实现显隐;利用CSS的.hidden类结合JavaScript的classList进行控制,利于维护和添加动画;使用模板字符串嵌入三元运算符动态生成HTML内容;以及通过data-属性存储状态…

    2025年12月23日
    000
  • 如何用HTML插入懒加载图片_HTML Intersection Observer API实现

    实现懒加载图片的核心思路是:页面初始只加载视口内图片,滚动时动态加载其余图片。使用 Intersection Observer API 监听元素进入视口,将 data-src 赋值给 src 并停止观察,配合占位图与 CSS 过渡提升体验,通过 rootMargin 提前加载附近图片,兼容性好且性能…

    好文分享 2025年12月23日
    000
  • 为什么HTML插入动画不循环_HTML CSS动画iteration-count属性设置

    animation-iteration-count是控制CSS动画播放次数的属性,默认值为1,即播放一次后停止;若要动画循环播放,需将其设置为infinite;常见问题包括未设置该属性、拼写错误、样式被覆盖或元素被移除等,正确使用可确保动画持续循环。 HTML中插入的CSS动画不循环,通常是因为an…

    2025年12月23日
    000
  • HTML标题标签怎么设置_HTML标题标签h1到h6用法

    h1至h6标签用于构建网页标题层级,h1为最高级主标题,h6为最低级,应逐级使用不可跳级,一个页面建议仅用一个h1突出主题,配合h2-h6形成逻辑结构,提升SEO与可访问性,避免为样式滥用标题标签,需用CSS控制外观,确保语义清晰、结构合理。 HTML标题标签用于定义网页中的标题和副标题,共有6个级…

    2025年12月23日
    000
  • 如何用HTML插入响应式图片_HTML picture标签与srcset属性适配方案

    使用 srcset 和 picture 实现响应式图片,根据设备分辨率和屏幕尺寸加载合适图像。srcset 支持多分辨率适配,如 1x/2x 或不同宽度版本,配合 sizes 定义显示宽度;picture 标签通过 media 查询实现艺术方向切换,为移动端裁剪、桌面端全景等场景提供不同构图。建议准…

    2025年12月23日 好文分享
    000

发表回复

登录后才能评论
关注微信