欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

拖拽功能by javascript 和 react 两种实现方法

程序员文章站 2022-03-29 19:47:14
使用鼠标移动图片或者移动图像怪有意思的,那这个移动的效果是怎么实现的呢? 在拖动的过程中,我们会涉及到鼠标向下按,以及移动图形,还有我们松开这几个步骤。 当我们将鼠标向下按的时候,我们鼠标点的这个动作,其实是有一个事件的,那如何确定鼠标 点的位置呢? 我们知道clientX 事件属性返回当事件被触发 ......

使用鼠标移动图片或者移动图像怪有意思的,那这个移动的效果是怎么实现的呢?
在拖动的过程中,我们会涉及到鼠标向下按,以及移动图形,还有我们松开这几个步骤。
当我们将鼠标向下按的时候,我们鼠标点的这个动作,其实是有一个事件的,那如何确定鼠标
点的位置呢?
我们知道clientx 事件属性返回当事件被触发时鼠标指针向对于浏览器页面(或客户区)的水平坐标。
clienty 事件属性返回当事件被触发时鼠标指针向对于浏览器页面(客户区)的垂直坐标。
这样我们就知道了鼠标点的坐标。
通过offsetleft,offsettop,我们可以求得对应图形左上角相对于浏览器的位置,即为我们移动图形的初始位置。
当我们松开这个图形的时候,通过clientx ,clienty获得当前鼠标的位置,我们可以通过鼠标移动的距离求得最后
我们图形的偏移量。
拖拽功能by javascript 和 react 两种实现方法
还有一个需要了解的是cursor这个属性,当它为defaulf的时候,它会是默认光标,为move的时候,为表示对象可以移动。
拖拽功能by javascript 和 react 两种实现方法
先看看我们原生js实现可拖拽的方法
拖拽功能by javascript 和 react 两种实现方法
在react中我们同样可以实现可拖拽的方法
我们可以定义一个drag组件,将组件渲染在我们的根元素中。
拖拽功能by javascript 和 react 两种实现方法
我们返回的这个组件,它本身很多东西都是可变的
拖拽功能by javascript 和 react 两种实现方法
刚开始的时候,我们要初始化鼠标点和图形左上角的坐标
拖拽功能by javascript 和 react 两种实现方法

当鼠标向下按的时候,我们会有图像或者鼠标的偏移量
拖拽功能by javascript 和 react 两种实现方法
最后是我们鼠标移动和停止的事件。
拖拽功能by javascript 和 react 两种实现方法
拖拽功能by javascript 和 react 两种实现方法
此博客升华自:
完整的demo见我的github:https://github.com/jserjser/reactwebapp/tree/master/demo