快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

Vue如何实现拖拽效果

小编给大家分享一下Vue如何实现拖拽效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

在昆山等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站设计、成都网站建设、外贸网站建设 网站设计制作按需策划设计,公司网站建设,企业网站建设,成都品牌网站建设,全网营销推广,成都外贸网站建设,昆山网站建设费用合理。

vue是什么

Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

效果图

Vue如何实现拖拽效果 

demo1.gif

分清clientY pageY screenY layerY offsetY的区别

在我们想要做出拖拽这个效果的时候,我们需要分清这几个属性的区别,这几个属性都是计算鼠标点击的偏移值,我们需要对其进行了解才可以继续实现我们的拖拽效果

clientY 指的是距离可视页面左上角的距离
pageY 指的是距离可视页面左上角的距离(不受页面滚动影响)
screenY 指的是距离屏幕左上角的距离
layerY 指的是找到它或它父级元素中最近具有定位的左上角距离
offsetY 指的是距离它自己左上角的距离
一张图带大家简单了解了解

Vue如何实现拖拽效果 

区别

在我们简单了解完这些个属性以后,有几个属性需要分清。


 相同点
不同点
clientY距离页面左上角距离受页面滚动的影响
pageY距离页面左上角的距离不受页面滚动影响

相同点不同点
layerY距离元素的左上角距离受元素的定位的影响,会从本元素往上找到第一个定位的元素的左上角
offsetY距离元素左上角的距离计算相对于本元素的左上角,不在乎定位问题,计算的是内交点。是IE浏览器的特有属性

Vue如何实现拖拽效果 

layerY与offsetY区别

实现拖拽功能

我们既然熟悉了这几个偏移属性的意思,那么我们就进入我们的重点。话不多说直接上代码

// darg.html



      
    {{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:{}, });

当然,我们可以将它绑定为一个自定义指令,这样的话就可以用调用指令的形式来实现拖拽效果,下面是定义自定义指令的代码

// darg.html



      
    
  
//main.js let app = new Vue({   el:'#app',   data:{},   methods:{},   directives: {     drag: {       // 指令的定义       bind: function (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;                         //绑定元素位置到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;           };         };       }     }   } });

以上是“Vue如何实现拖拽效果”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


名称栏目:Vue如何实现拖拽效果
浏览路径:http://6mz.cn/article/pppccd.html

其他资讯