如何通过 JavaScript 中的事件悬停来动态设置具有同一类的多个元素的样式?
如何使用 JavaScript 为同一类的多个元素设置样式
使用 HTML 和 CSS 时,有时需要动态更改样式具有同一类的多个元素。在本例中,问题是当鼠标悬停在另一个页面元素上时,使用 getElementsByClassName 更改具有给定类的所有元素的背景颜色。
出现问题是因为 getElementsByClassName 返回元素的集合,而不是单个元素。要设置多个元素的样式,您需要循环遍历集合并将样式更改应用到每个元素。
<code class="js">var elements = document.getElementsByClassName('classname'); for (var i = 0; i < elements.length; i++) { elements[i].style.backgroundColor = 'red'; }
登录后复制
另一个问题是悬停事件未正确附加到目标元素。在原始代码中, onmouseover 事件附加到触发元素(悬停在其上的元素)。要更改目标元素的样式,应将事件附加到目标元素本身。
<code class="html"><th class="classname" onmouseover="changeColor(this)">Hover Here</th></code>
登录后复制
最后,需要注意的是,不建议使用 onmouseover 等内联事件处理程序。相反,您应该使用事件侦听器将事件处理程序附加到元素。
<code class="js">function changeColor(element) { element.style.backgroundColor = 'red'; } document.querySelectorAll('.classname').forEach((element) => { element.addEventListener('mouseover', () => { changeColor(element); }); });</code>
登录后复制
通过使用这些技术,当将鼠标悬停在另一个页面元素上时,您可以动态更改具有同一类的多个元素的样式。
以上是如何通过 JavaScript 中的事件悬停来动态设置具有同一类的多个元素的样式?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章
Windows 11 KB5054979中的新功能以及如何解决更新问题
4 周前
By DDD
如何修复KB5055523无法在Windows 11中安装?
3 周前
By DDD
Inzoi:如何申请学校和大学
1 个月前
By DDD
如何修复KB5055518无法在Windows 10中安装?
3 周前
By DDD
在哪里可以找到Atomfall中的站点办公室钥匙
4 周前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)