zoukankan      html  css  js  c++  java
  • el-dialog拖拽功能

    开始也是用vue自定义指令来实现,后来发现一个页面中有两个el-dialog时,只有一个起作用,求指点。。。

    所以写了一个全局的方法来调用。

     
    ~/utils/dialogDrag.js

    1
    export default { 2 dialogDrag(el) { 3 let dragDom = el.querySelector('.el-dialog'); 4 let dragDomHeader = el.querySelector('.el-dialog__header'); 5 dragDomHeader.style.cursor = 'move'; 6 dragDomHeader._isDrag = false; 7 // 鼠标按下事件 8 // onmousedown事件绑定之所以在el-dialog__header上,是因为绑定在el-dialog时弹框中的表单会无法编辑 9 dragDomHeader.onmousedown = (e) => { 10 dragDomHeader._isDrag = true; 11 // 鼠标相对元素的位置 12 dragDomHeader._startX = e.clientX - dragDomHeader.offsetLeft; 13 dragDomHeader._startY = e.clientY - dragDomHeader.offsetTop; 14 e.preventDefault(); 15 }; 16 document.onmousemove = (e) => { 17 if (dragDomHeader._isDrag) { 18 // 鼠标的位置减去鼠标相对元素的位置得到元素的位置 19 let _endX = e.clientX - dragDomHeader._startX; 20 let _endY = e.clientY - dragDomHeader._startY; 21 dragDom.style.left = _endX + 'px'; 22 dragDom.style.top = _endY + 'px'; 23 } 24 }; 25 document.onmouseup = () => { 26 dragDomHeader._isDrag = false; 27 }; 28 } 29 };
     index.vue

    1
    <template> 2 <el-dialog @open="openDialog" ref="dialog"> 3 </el-dialog> 4 </template> 5 6 <script> 7 import DialogDrag from '~/utils/dialogDrag'; 8 9 methods: { 10 openDialog() { 11 DialogDrag.dialogDrag(this.$refs.dialog.$el); 12 } 13 } 14 </script>
  • 相关阅读:
    Qt类继承关系图
    回归Qt——写在Qt5.10发布之日
    Jdk1.7下的HashMap源码分析
    Jdk1.8下的HashMap源码分析
    八皇后||算法
    设计模式之一单例模式
    多线程之美8一 AbstractQueuedSynchronizer源码分析<二>
    多线程之美7一ReentrantReadWriteLock源码分析
    多线程之美6一CAS与自旋锁
    多线程之美5一 AbstractQueuedSynchronizer源码分析<一>
  • 原文地址:https://www.cnblogs.com/zoey-blog/p/12718768.html
Copyright © 2011-2022 走看看