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 相当于浏览器可视窗口的左上角为原点,即不包括被被隐藏的距离;
实现拖拽功能
{{positionX}} {{positionY}} //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; }; } } });以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持爱蒂网。
您可能感兴趣的文章:
- 基于Vue实现拖拽效果
- Vue.Draggable实现拖拽效果
- Vue自定义指令拖拽功能示例
- vuedraggable+element ui实现页面控件拖拽排序效果
- vue使用drag与drop实现拖拽的示例代码
- vue实现element-ui对话框可拖拽功能
- vue2.0使用Sortable.js实现的拖拽功能示例
- 基于Vue实现拖拽功能
- Vue拖拽组件开发实例详解
- Vue.Draggable拖拽功能的配置使用方法
推荐阅读vue实现弹幕功能
阅读 652 / 2019-12-30 11:38:02
解决vue打包后刷新页面报错:Unexpected token <
阅读 448 / 2019-12-30 11:46:40
微信小程序iOS下拉白屏晃动问题解决方案
阅读 402 / 2019-12-30 11:38:59
浅谈laytpl 模板空值显示null的解决方法及简单的js表达式
阅读 397 / 2019-12-30 11:42:49
layui表格 列自动适应大小失效的解决方法
阅读 388 / 2019-12-30 11:43:37
vue的路由映射问题及解决方案
阅读 336 / 2019-12-30 11:38:44
Element-Ui组件 NavMenu 导航菜单的具体使用
阅读 332 / 2019-12-30 11:38:10
Vue 3.0双向绑定原理的实现方法
阅读 322 / 2019-12-30 11:38:25
猜你喜欢