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

vue2x添加一个元素拖拽功能

拖拽元素绑定:

 
<div class="add-twin-wrap-container"><div class="add-twin-wrap" @click.stop><p class="title" @mousedown="onDragStart">添加场景类型实例<span class="icon iconfont avw-cancel" @click="$emit('close-dialog')"></span></p><div class="twin-cont">...........</div></div></div>

初始化元素样式:

  mounted() {// 初始化 left/top,使拖动计算准确const dialog = this.$el.querySelector('.add-twin-wrap');const rect = dialog.getBoundingClientRect();dialog.style.left = `${rect.left}px`;dialog.style.top = `${rect.top}px`;},

 

添加拖拽监听方法:

methods: {// ...原来的方法不动onDragStart(e) {const dialog = this.$el.querySelector('.add-twin-wrap');const rect = dialog.getBoundingClientRect();// 鼠标点击位置相对弹窗左上角的偏移const offsetX = e.clientX - rect.left;const offsetY = e.clientY - rect.top;// 防止选中文字document.body.style.userSelect = 'none';const onMouseMove = (moveEvent) => {const left = moveEvent.clientX - offsetX;const top = moveEvent.clientY - offsetY;// 限制不要拖出屏幕const maxLeft = window.innerWidth - rect.width;const maxTop = window.innerHeight - rect.height;dialog.style.left = Math.min(Math.max(0, left), maxLeft) + 'px';dialog.style.top = Math.min(Math.max(0, top), maxTop) + 'px';};const onMouseUp = () => {document.removeEventListener('mousemove', onMouseMove);document.removeEventListener('mouseup', onMouseUp);document.body.style.userSelect = '';};document.addEventListener('mousemove', onMouseMove);document.addEventListener('mouseup', onMouseUp);},
}

 

http://www.gsyq.cn/news/33805.html

相关文章:

  • 直扩信号参数估计:载频、码速率和扩频增益
  • 2025 年防爆位移传感器厂家联系方式推荐,杭州浙达精益提供专业设备与可靠技术支持
  • 2025年振弦式频率读数仪609供货厂家权威推荐榜单:读数仪609/测读仪读数仪609/土木工程用609读数仪源头厂家精选
  • 直播|均降 40% 的 GPU 成本,大规模 Agent 部署和运维的捷径是什么?
  • 2025年户外面料厂家推荐排行榜:尼龙/涤纶/尼龙格子/珍珠点/登山布/户外速干/瑜伽/梭织/TR消光面料公司推荐
  • 2025年铝单板厂家推荐排行榜,氟碳铝单板,仿木纹铝单板,仿石材铝单板,幕墙装饰铝单板公司精选
  • 基于Matlab的深度堆叠自编码器(SAE)实现与分类应用
  • WComputer2027.1下载 WComputer2027.1 downloadWComputer2027.1ダウンロード
  • 2025 年工业不锈钢管,激光切割不锈钢管,铁管不锈钢管厂家最新推荐,产能、专利、环保三维数据透视
  • 2025 年不锈钢管圆筒,焊管不锈钢管,花纹不锈钢管,菱形不锈钢管厂家最新推荐,技术实力与市场口碑深度解析
  • 【大数据高并发核心场景实战】 数据持久化层 - 查询分离
  • 2025 保研辅导,保研机构,保研星途,保研规划机构最新推荐,聚焦资质、案例、售后的五家机构深度解读
  • 2025年气缸管厂家权威推荐榜:精密气缸管,不锈钢气缸管,珩磨气缸管,薄壁气缸管,焊接气缸管,冷拔气缸管,食品级气缸管,海洋用气缸管专业供应商
  • 20251029
  • 2025年反应釜厂家权威推荐榜:搪玻璃反应釜/搪瓷反应釜/开式闭式反应釜/非标搪玻璃反应釜专业选购指南
  • jmeter 创建100个现场组,每个线程组里面有1个http请求,http接口内容为读取CSV文件
  • 2025 年 5 吨电子地磅,18 米电子地磅,无人值守电子地磅厂家最新推荐,产能、专利、环保三维数据透视
  • C 程序的内存分区结构
  • 2025年手持式光谱仪厂家权威推荐榜:XRF/LIBS手持式、便携式X射线荧光、土壤测铝、合金分析仪专业测评
  • 2025年净气活性炭定做厂家权威推荐:除味活性炭工厂/废气净化活性炭源头厂家/空气净化活性炭厂家精选
  • 2025年超声波分散设备厂商权威推荐榜单:进口超声波分散设备/本多超声波分散设备/双频超声波分散设备源头厂家精选
  • CH5xx 蓝牙主机低功耗测试
  • sg.window有哪些属性和方法
  • QPSK/BPSK在多径信道下经过LMS均衡器后的误码率曲线分析
  • 2025年10月中国管理咨询公司实力榜:金蓝盟领衔五强横向评测
  • 2025年10月精益管理咨询公司推荐:实力榜排名与场景指南
  • 制药行业MES系统功能设计
  • 2025年10月精益降本咨询公司推荐:口碑榜对比指南
  • 2025年福祉座椅厂家权威推荐榜单:轮椅升降机/轮椅升降平台/福祉车源头厂家精选
  • AIGC与智能体平台 Coze Dify N8N公开课