一些开发人员在尝试纯模拟鼠标悬停功能时遇到了问题尽管触发了鼠标悬停侦听器,JavaScript 也不会触发 CSS 悬停声明。本文旨在解决这一挑战并探索潜在的解决方案。
问题的核心在于浏览器中事件信任级别的概念。由用户交互或 DOM 更改触发的事件被视为可信事件并具有某些特权。相反,JavaScript 代码通过 DocumentEvent.createEvent 或 EventTarget.dispatchEvent 方法生成的事件被视为不受信任的事件。
不受信任事件缺乏触发“悬停”样式是由于安全限制。浏览器限制由不受信任的事件触发的默认操作,但单击或 DOMActivate 等操作除外。这是一种故意的措施,旨在防止恶意代码模拟用户交互并可能危及安全。
要模拟鼠标悬停效果,解决方案在于手动添加和删除 CSS检测到 mouseover 和 mouseout 事件时的类。这种方法有效地触发CSS“:hover”声明,而不依赖于不受信任的事件。下面是一个示例实现:
// Simulate mouseover effect element.addEventListener("mouseover", () => { element.classList.add("hover"); }); // Simulate mouseout effect element.addEventListener("mouseout", () => { element.classList.remove("hover"); });
通过实现此解决方案,您可以模拟鼠标悬停事件并触发所需的 CSS 悬停样式,而不会违反浏览器安全限制。
以上是为什么 JavaScript 鼠标悬停不总是触发 CSS :hover?的详细内容。更多信息请关注PHP中文网其他相关文章!