设置弹窗随鼠标位置移动

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;
  }
});
相关推荐
❀͜͡傀儡师10 分钟前
docker部署Docker Compose文件Web管理工具Dockman
java·前端·docker·dockman
karshey26 分钟前
【前端】sort:js按照固定顺序排序
开发语言·前端·javascript
MyBFuture27 分钟前
索引器实战:对象数组访问技巧及命名空间以及项目文件规范
开发语言·前端·c#·visual studio
IT_陈寒36 分钟前
Redis性能提升50%的7个实战技巧,连官方文档都没讲全!
前端·人工智能·后端
打小就很皮...39 分钟前
React 富文本图片上传 OSS 并防止 Base64 图片粘贴
前端·react.js·base64·oss
咬人喵喵1 小时前
告别无脑 <div>:HTML 语义化标签入门
前端·css·编辑器·html·svg
404NotFound3051 小时前
基于 Vue 3 和 Guacamole 搭建远程桌面(利用RDP去实现,去除vnc繁琐配置)
前端
咚咚咚ddd1 小时前
AI 应用开发:Agent @在线文档功能 - 前端交互与设计
前端·aigc·agent
旧梦吟1 小时前
脚本工具 批量md转html
前端·python·html5