当前位置: 首页 > news >正文

如何在Vue中实现鼠标悬浮展示与隐藏弹窗的功能

如果你需要鼠标在元素和弹窗上时保持弹窗显示,而鼠标离开这两者时隐藏弹窗,你可以使用一个稍微复杂的逻辑来处理鼠标的进入和离开事件。

这通常涉及到延时关闭弹窗,以便给用户足够的时间从元素移动到弹窗上,而不触发弹窗关闭。以下是一个实现的例子:(这个例子简单,效果还非常好)

<template><div><!-- 悬停目标元素 --><div @mouseenter="delayedOpen" @mouseleave="delayedClose">悬停我查看弹窗</div><!-- 弹窗元素 --><div v-if="isPopupVisible"@mouseenter="clearCloseTimeout"@mouseleave="delayedClose"class="popup">这是弹窗内容</div></div>
</template><script>
export default {data() {return {isPopupVisible: false,closeTimeout: null,};},methods: {delayedOpen() {this.clearCloseTimeout();this.isPopupVisible = true;},delayedClose() {// 设置一个延时,给用户时间移动到弹窗上this.closeTimeout = setTimeout(() => {this.isPopupVisible = false;}, 300); // 延时300毫秒关闭},clearCloseTimeout() {// 清除已设定的延时关闭,防止弹窗意外关闭if (this.closeTimeout) {clearTimeout(this.closeTimeout);this.closeTimeout = null;}}}
};
</script><style>
.popup {position: absolute;width: 200px;height: 100px;background-color: white;border: 1px solid #ccc;box-shadow: 0px 0px 10px rgba(0,0,0,0.1);padding: 10px;
}
</style>

功能解释

  • delayedOpen 方法用于立即显示弹窗,同时清除之前可能设置的关闭延时。
  • delayedClose 方法设置一个延时,允许用户有足够的时间将鼠标从悬停元素移动到弹窗上。
  • clearCloseTimeout 方法用于取消已设置的延时关闭,这通常在鼠标从元素移到弹窗上时调用。

通过这种方法,弹窗能够在鼠标悬停在触发元素和弹窗本身上时保持显示,并且在鼠标离开这些区域后,经过一个短暂的延时后自动关闭。这为用户提供了更自然的交互体验。

http://www.lryc.cn/news/350564.html

相关文章:

  • 03 Linux编程-进程
  • Hbuild-X运行ios基座app
  • Node.js基础:从入门到实战
  • 考研408笔记总结~
  • 使用在线工具等方式下载推特视频
  • 性能优化:几方面考虑
  • 学习大数据:论学习Spark的重要性
  • 学习java第七十一天
  • Altium Designer PCB快捷键设置
  • 玩转Matlab-Simscape(初级)- 08 - 基于Solidworks、Matlab Simulink、COMSOL的协同仿真(案例实战)
  • vue嵌套路由
  • 视频降噪算法 hqdn3d 原理分析
  • Ansys Mechanical|屈曲分析技术
  • 【大模型微调】一文掌握7种大模型微调的方法
  • MySQL表突然卡死,删、查操作加载不停解决办法
  • Rust 标准库的结构及其模块路径
  • 003_PyCharm的安装与使用
  • 事件传递机制
  • DE2-115串口通信
  • Danfoss丹佛斯S90泵比例放大器
  • 对话YashanDB CTO陈志标:如何推动国产数据库长远发展
  • ip显示地址和实际地址不一样:原因解析与应对策略
  • visual studio snippet常用注释片段
  • ubuntu下不生成core dumped
  • python开发的学习路线
  • vite+vue3 部署后,总是需要清除缓存的问题
  • 多态:解锁面向对象编程的无限可能
  • 学习MySQL(四):记录的增删改查
  • 如何使用Python进行网页爬取
  • Spring的IOC(Inversion of Control)设计模式