码迷,mamicode.com
首页 > 其他好文 > 详细

react实现拖拽

时间:2018-11-29 21:17:58      阅读:1145      评论:0      收藏:0      [点我收藏+]

标签:ret   判断   tno   拖动   ack   tar   document   return   event   

import React from ‘react‘

export default class extends React.Component {
constructor(props) {
super(props);
this.state = {
translateX: 0,
translateY: 0,
};
}
small_down=(e)=> {
var obig = this.refs.move.parentNode;
var osmall = this.refs.move;
var e = e || window.event;
/*用于保存小的div拖拽前的坐标*/
osmall.startX = e.clientX - osmall.offsetLeft;
osmall.startY = e.clientY - osmall.offsetTop;
/*鼠标的移动事件*/
document.onmousemove = function(e) {
var e = e || window.event;
osmall.style.left = e.clientX - osmall.startX + "px";
osmall.style.top = e.clientY - osmall.startY + "px";
/*对于大的DIV四个边界的判断*/
let x=obig.offsetWidth-osmall.offsetWidth
let y=obig.offsetHeight-osmall.offsetHeight
if (e.clientX - osmall.startX <= 0) {
osmall.style.left = 0 + "px";
}
if (e.clientY - osmall.startY <= 0) {
osmall.style.top = 0 + "px";
}
if (e.clientX - osmall.startX >= x) {
osmall.style.left = x + "px";
}
if (e.clientY - osmall.startY >= y) {
osmall.style.top = y + "px";
}
};
/*鼠标的抬起事件,终止拖动*/
document.onmouseup = function() {
document.onmousemove = null;
document.onmouseup = null;
};
}
componentDidMount(){

}
render() {
return (
<div
style={{ width:"500px" ,height:"500px" ,background:"red" ,margin:"0 auto" ,position:"relative"}}
>
<div ref="move" onMouseDown={e => this.small_down(e)} style={{position:"absolute", left: `${this.state.translateX}px`,top:`${this.state.translateY}px`, width: 100, height: 100, backgroundColor: ‘blue‘, }} />
</div>
)
}
};

react实现拖拽

标签:ret   判断   tno   拖动   ack   tar   document   return   event   

原文地址:https://www.cnblogs.com/liuerpeng/p/10040794.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!