vue - pc端实现对div的拖动功能

实现对div的拖动功能,需要先要知道以下的一些原生事件和方法;

1,事件:

方法描述onmousedown鼠标按钮被按下onmousemove鼠标被移动onmouseup鼠标按键被松开2,方法:

方法描述event.clientX返回当事件被触发时鼠标指针相对于浏览器页面(或窗口)的水平坐标event.clientY同上,返回的是垂直坐标event.offsetLeft只读属性,返回当前元素左边框距定位元素(或者最近的元素) 左侧的像素值event.offsetTop只读属性,返回当前元素上边框距定位元素(或者最近的元素) 顶部的像素值event.clientHeight只读属性,返回该元素的像素高度,高度包含内边距(padding),不包含边框(border),外边距(margin)和滚动条,是一个整数,单位是像素 pxevent.clientWidth同上,返回该元素的像素宽度event.offsetHeight只读属性,它返回该元素的像素高度,高度包含内边距(padding)和边框(border),不包含外边距(margin),是一个整数,单位是像素 pxevent.offsetWidth同上,返回该元素的像素宽度注意:clientHeight ,clientWidth 和 offsetHeight offsetWidth 获取元素高度宽度的尺寸不太一样,我这边使用的的 offsetHeight offsetWidth;

图例说明:

实现的效果图如下:

3,实现如下:

重要说明:

1,mousedown() 鼠标按下时需要计算位置差,因为clientX和offsetLeft的属性返回的位置不一样 要相减得到鼠标在拖动元素内实际点击的位置, 后面每一次拖动时都要减去这个差值 否则就会造成你拖动的位置一直都是元素的左上角 而不是你之前点击的位置;

2,onmousemove ()鼠标移动事件和onmouseup 鼠标抬起事件要添加到 document 元素上面,因为在拖动的过程中如果拖动过快,鼠标移出了拖动元素,导致拖动元素丢失了移动事件;

3,拖动限制范围的判断建议使用第二种方法,第一种我这边演示的时候发现div靠边时经常会有间隙,不太流畅;

4,onmouseup鼠标抬起时需要解绑鼠标移动事件;

drag.vue

相关文章

《哔哩哔哩》私信查看方法

Photoshop详细解析夜景风光如何后期修图

汽车电瓶放多久会没电