鼠标拖拽元素以及继承原生代码

Posted 1179929172-zh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了鼠标拖拽元素以及继承原生代码相关的知识,希望对你有一定的参考价值。

实现页面上两个DOM元素的操作,通过继承的方式
class Drag
constructor(ele)
this.ele = ele;
this.m = this.move.bind(this);
this.u = this.up.bind(this);
this.addEvent();
addEvent()
this.ele.addEventListener("mousedown",this.down.bind(this))
down(eve)
var e = eve || window.event;
this.x = e.offsetX;
this.y = e.offsetY;
document.addEventListener("mousemove",this.m);
document.addEventListener("mouseup",this.u);
move(eve)
var e = eve || window.event;
this.ele.style.left = e.clientX - this.x + "px";
this.ele.style.top = e.clientY - this.y + "px";
up()
document.removeEventListener("mousemove",this.m);
document.removeEventListener("mouseup",this.u);

class SmallDrag extends Drag
constructor(ele)
super(ele)
move(eve)
var e = eve || window.event;

var l = e.clientX - this.x;
var t = e.clientY - this.y;

if(l < 0)
l = 0;
if(t < 0)
t = 0;

this.ele.style.left = l + "px";
this.ele.style.top = t + "px";

var obox1 = document.getElementById("box1")
var obox2 = document.getElementById("box2")

new Drag(obox1);

new SmallDrag(obox2);

以上是关于鼠标拖拽元素以及继承原生代码的主要内容,如果未能解决你的问题,请参考以下文章

原生js实现拖拽效果

JS实现鼠标拖拽效果以及放大缩小

angular项目中输入延迟以及拖拽卡顿

Drag,js实现鼠标拖拽元素

Drag,js实现鼠标拖拽元素

js原生代码实现鼠标拖拽(超简单)