在实现拖放(drag & drop)功能时,常因鼠标位置残留导致 `mouseenter` 错误触发相邻元素;本文提供一种精准、低侵入的解决方案:拖放结束时临时禁用 `mouseenter` 监听器,并在首次鼠标移动后立即恢复,彻底避免伪悬停。
该问题本质并非浏览器 Bug,而是拖放交互中鼠标状态与事件调度的耦合现象:当用户拖动一个 .person 元素(如“Person A”)时,原生拖放机制会抑制常规鼠标事件(如 mouseenter/mouseleave),但拖放结束后,鼠标指针仍停留在拖拽起始 
直接移除监听器或全局禁用 mouseenter 并不可取:前者破坏功能完整性,后者影响用户体验。更优解是事件生命周期协同控制——利用 dragend 捕获拖放终止时机,临时解绑监听器;再通过 mousemove 的一次性监听(.one())确保仅在用户真实移动鼠标后才恢复监听,既规避了静止状态下的误触发,又保留了后续所有正常交互。
以下是推荐的生产级实现代码:
$(document).ready(function() {
// 定义可复用的 hover 处理函数
const handlePersonHover = (event) => {
$("#log").val($("#log").val() + "\nHover on " + event.target.innerText.trim());
};
// 绑定初始 mouseenter 监听
$(document).on("mouseenter", ".person", handlePersonHover);
// 在 dragend 时临时禁用 mouseenter,避免拖放结束后的残留触发
$(document).on("dragend", function() {
$(document).off("mouseenter", ".person", handlePersonHover);
// 仅监听下一次 mousemove,随后自动恢复监听
$(document).one("mousemove", function() {
$(document).on("mouseenter", ".person", handlePersonHover);
});
});
});✅ 关键优势说明:
⚠️ 注意事项:
该方案已在多个 Kanban 类项目中稳定运行,有效消除 99%+ 的误触发场景,兼顾健壮性与可维护性。