谷歌浏览器插件 录制元素拖动事件

背景

最近在开发谷歌浏览器录制插件的过程中,发现无法监听 vue2 项目的元素拖动事件,拖拽组件使用的是 vue2 的vue-smooth-dnd 包。

正常未使用第三方拖拽库的元素已经可以监听到其拖拽事件,使用了上述第三方库的时候,元素拖拽事件无法监听。

解决思路

一番研究后发现vue-smooth-dnd 使用鼠标事件模拟拖拽,而非 HTML5 原生拖拽事件。因此,需监听鼠标事件或库的自定义事件。

vue-smooth-dnd 库会触发以下关键事件:

  • @drag-start: 拖拽开始时触发
  • @drag-end: 拖拽结束时触发
  • @drop: 元素放置时触发

在尝试监听 drag 等事件发现无效后,无法捕获自定义事件,采取监听 鼠标事件来处理拖拽行为。

js 复制代码
// content-script.js
let isDragging = false;
let startX, startY;

document.addEventListener('mousedown', (e) => {
  if (e.target.closest('.smooth-dnd-container')) { // 检查目标元素
    isDragging = true;
    [startX, startY] = [e.clientX, e.clientY];
  }
});

document.addEventListener('mousemove', (e) => {
  if (isDragging) {
    const dx = e.clientX - startX;
    const dy = e.clientY - startY;
    // 如果移动超过阈值,判定为拖拽中
    if (Math.abs(dx) > 5 || Math.abs(dy) > 5) {
      console.log('拖拽中...', { dx, dy });
    }
  }
});

document.addEventListener('mouseup', () => {
  if (isDragging) {
    console.log('拖拽结束');
    isDragging = false;
  }
});

注意事项

  • 性能优化 :避免在 mousemove 中执行高频率操作,可添加防抖。
  • 选择器适配 :根据实际项目调整 .smooth-dnd-container 选择器。此处需要注意,不同拖拽库对应的 css 选择器可能不同,需要注意,处理对应兼容。

通过以上方法,插件应能正确录制 vue-smooth-dnd 的拖拽行为。

相关推荐
程序员清洒9 小时前
Flutter for OpenHarmony:Text — 文本显示与样式控制
开发语言·javascript·flutter
雨季6669 小时前
Flutter 三端应用实战:OpenHarmony 简易“动态内边距调节器”交互模式深度解析
javascript·flutter·ui·交互·dart
天人合一peng9 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
会飞的战斗鸡10 小时前
JS中的链表(含leetcode例题)
javascript·leetcode·链表
方也_arkling10 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐10 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
qq_1777673710 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_1777673710 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
web打印社区11 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO11 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素