使用Vue操作DIV的方法

小编给大家分享一下使用Vue操作DIV的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

成都网站制作、网站设计,成都做网站公司-成都创新互联公司已向1000多家企业提供了,网站设计,网站制作,网络营销等服务!设计与技术结合,多年网站推广经验,合理的价格为您打造企业品质网站。

效果图

使用Vue操作DIV的方法

demo1.gif

分清clientY pageY screenY layerY offsetY的区别

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

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

使用Vue操作DIV的方法

区别

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


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

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

使用Vue操作DIV的方法

layerY与offsetY区别

实现拖拽功能

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

// darg.html



      
    {{positionX}}
    {{positionY}}
  

//main.js let app = new Vue({   el:'#app',   data:{     positionX:0,     positionY:0,   },   methods:{     move(e){       let op = e.target;    //获取目标元素              //算出鼠标相对元素的位置       let disX = e.clientX - op.offsetLeft;       let disY = e.clientY - op.offsetTop;       document.onmousemove = (e)=>{    //鼠标按下并移动的事件         //用鼠标的位置减去鼠标相对元素的位置,得到元素的位置         let left = e.clientX - disX;           let top = e.clientY - disY;                  //绑定元素位置到positionX和positionY上面         this.positionX = top;         this.positionY = left;                  //移动当前元素         op.style.left = left + 'px';         op.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 op = el;  //获取当前元素         op.onmousedown = (e) => {           //算出鼠标相对元素的位置           let disX = e.clientX - op.offsetLeft;           let disY = e.clientY - op.offsetTop;                      document.onmousemove = (e)=>{             //用鼠标的位置减去鼠标相对元素的位置,得到元素的位置             let left = e.clientX - disX;               let top = e.clientY - disY;                         //绑定元素位置到positionX和positionY上面             this.positionX = top;             this.positionY = left;                      //移动当前元素             op.style.left = left + 'px';             op.style.top = top + 'px';           };           document.onmouseup = (e) => {             document.onmousemove = null;             document.onmouseup = null;           };         };       }     }   } });

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


当前文章:使用Vue操作DIV的方法
文章源于:http://myzitong.com/article/ggepeo.html