vue实现拖拽效果
程序员文章站
2022-07-06 18:19:15
vue中实现拖拽效果,供大家参考,具体内容如下
首先要搞明白分清clienty pagey screeny layery offsety的区别
作用3(事件对象中记录的鼠标位置)...
vue中实现拖拽效果,供大家参考,具体内容如下
首先要搞明白分清clienty pagey screeny layery offsety的区别
作用3(事件对象中记录的鼠标位置)
语法 解释
evt.screenx 相对于屏幕的左上角为原点
evt.screeny
evt.clientx 相对于浏览器的客户端左上角为原点(不计算滚动条位置)
evt.clienty
evt.pagex 相对于浏览器的客户端左上角为原点(计算滚动条的位置)
evt.pagey
evt.offsetx 以自己的左上角为原点
evt.offsety
evt.pagey/evt.pagex 相当于文档的左上角为原点,即包括被被隐藏的距离;
evt.clienty/evt.clientx 相当于浏览器可视窗口的左上角为原点,即不包括被被隐藏的距离;
实现拖拽功能
<style> #app{ position: relative; /*定位*/ top: 10px; left: 10px; width: 200px; height: 200px; background: #666; /*设置一下背景*/ } </style> <body> <div id="app" @mousedown="move"> <!--绑定按下事件--> {{positionx}} {{positiony}} </div> </body> //main.js let app = new vue({ el:'#app', data:{ positionx:0, positiony:0, }, methods:{ move(e){ let odiv = e.target; //获取目标元素 //算出鼠标相对元素的位置 let disx = e.clientx - odiv.offsetleft; let disy = e.clienty - odiv.offsettop; document.onmousemove = (e)=>{ //鼠标按下并移动的事件 //用鼠标的位置减去鼠标相对元素的位置,得到元素的位置 let left = e.clientx - disx; let top = e.clienty - disy; //绑定元素位置到positionx和positiony上面 this.positionx = top; this.positiony = left; //移动当前元素 odiv.style.left = left + 'px'; odiv.style.top = top + 'px'; }; document.onmouseup = (e) => { document.onmousemove = null; document.onmouseup = null; }; } }, computed:{}, });
当然,我们可以将它绑定为一个自定义指令,这样的话就可以用调用指令的形式来实现拖拽效果,下面是定义自定义指令的代码
在main.js中定义全局指令
vue.directive('drag' drag: { // 指令的定义 bind(el) { let odiv = el; //获取当前元素 odiv.onmousedown = (e) => { //算出鼠标相对元素的位置 let disx = e.clientx - odiv.offsetleft; let disy = e.clienty - odiv.offsettop; document.onmousemove = (e)=>{ //用鼠标的位置减去鼠标相对元素的位置,得到元素的位置 let left = e.clientx - disx; let top = e.clienty - disy; if(left<3) { left=0; odiv.style.width="2px"; }else{odiv.style.width="auto";} if(left>innerwidth-odiv.offsetwidth) {left=innerwidth- odiv.offsetwidth;odiv.style.width="2px";} //移动当前元素 odiv.style.left = left + 'px'; odiv.style.top = top + 'px'; }; document.onmouseup = (e) => { document.onmousemove = null; document.onmouseup = null; }; } } });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。