设置弹窗随鼠标位置移动

1.这是要移动的弹窗,隐藏显示逻辑、样式、展示内容自己写,主要就是动态设置弹窗的style,floatLeft和floatTop都是Vue中的data双向绑定数据;

html 复制代码
<div id="box" v-show="hasMove" :style="{ left: floatLeft + 'px', top: floatTop + 'px' }">
   <p>{{ Math.round(distanceSum) }}米</p>
</div>

2.计算弹窗位置主要就是拿到鼠标位置屏幕坐标系和弹窗左上角位置绑定,但是要注意设置鼠标位置在四周边缘的时候, 弹窗不应该被屏蔽遮挡到;

javascript 复制代码
window.addEventListener("mousemove", function (e) {
  // 设置鼠标位置和弹窗左上角的位置
  that.floatLeft = e.pageX + 10;
  that.floatTop = e.pageY - 30;
  // 解决不同浏览器可视区域参数不统一的问题
  let width =
    e.view.innerWidth > e.view.outerWidth
      ? e.view.innerWidth
      : e.view.outerWidth;
  // 设置鼠标位置在屏幕右侧的时候弹窗位置
  if (e.pageX > width - 100) {
    that.floatLeft = width - 100;
  }
  // 设置鼠标位置在屏幕上边的时候弹窗位置
  if (e.pageY < 20) {
    that.floatTop = e.pageY;
  }
  // 设置鼠标位置在屏幕下边的时候弹窗位置
  if (e.pageY > e.view.outerHeight - 10) {
    that.floatTop = e.view.outerHeight - 20;
  }
});
相关推荐
一 乐32 分钟前
基于vue船运物流管理系统设计与实现(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端·船运系统
m0_5287238142 分钟前
在React中使用redux
前端·javascript·react.js
傻小胖1 小时前
vue3中customRef的用法以及使用场景
前端·javascript·vue.js
谦谦橘子1 小时前
手把手教你实现一个富文本
前端·javascript
Future_yzx1 小时前
Java Web的发展史与SpringMVC入门学习(SpringMVC框架入门案例)
java·前端·学习
star010-1 小时前
【视频+图文详解】HTML基础4-html标签的基本使用
前端·windows·经验分享·网络安全·html·html5
engchina1 小时前
CSS Display属性完全指南
前端·css
engchina1 小时前
详解CSS `clear` 属性及其各个选项
前端·css·css3
车载诊断技术2 小时前
基于新一代电子电器架构的SOA服务设计方法
人工智能·架构·汽车·计算机外设·ecu故障诊断指南
yashunan3 小时前
Web_php_unserialize
android·前端·php