js 实现div随鼠标拖拽(面向对象)
来源:学习编程     阅读:991
动风网络
发布于 2018-07-25 23:23
查看主页

上一篇文章实现了div鼠标进行拖拽,这次用面向对象的思想进行重写,面向对象的好处就是以后修改功能可以直接进行继承,只需修改自己关心的部分就可.

有关js面向对象,可以参考js 实现面向对象

没什么好说的了,直接放代码吧,没什么难度

/*

实现div随鼠标移动实现拖拽效果

div需指定宽高, position:absolute;

参数:

id: div的id

示例:

new Drag('div1');

*/

function Drag(id){

var _this=this;

this.disX=0;

this.disY=0;

this.oDiv=document.getElementById(id);

// 鼠标在div中按下,调使用方法

this.oDiv.onmousedown=function (){

_this.fnDown();

};

}

// 鼠标按下时调使用的方法

Drag.prototype.fnDown=function (ev){

var _this=this;

var oEvent=ev||event;

// 保存鼠标在div的位置

this.disX=oEvent.clientX-this.oDiv.offsetLeft;

this.disY=oEvent.clientY-this.oDiv.offsetTop;

document.onmousemove=function (){

_this.fnMove();

};

document.onmouseup=function (){

_this.fnUp();

};

// 阻止默认事件,防止移动过程中会选中内容

oEvent.preventDefault();

};

// 鼠标移动时调使用的方法

Drag.prototype.fnMove=function (ev){

var oEvent=ev||event;

// 修改div的位置

this.oDiv.style.left=oEvent.clientX-this.disX+'px';

this.oDiv.style.top=oEvent.clientY-this.disY+'px';

};

// 鼠标松开时调使用的方法

Drag.prototype.fnUp=function (){

document.onmousemove=null;

document.onmouseup=null;

};

免责声明:本文为用户发表,不代表网站立场,仅供参考,不构成引导等用途。 网页前端 JS
相关推荐
Android 绘制原理浅析「干货」
Javascript ES6 Iterators建议指南(含实例)
说说如何在 Java 中执行 JavaScript 脚本
使用githubpages主题NexT的语法
Tomcat点击Manager App不报401错误,配置流程
首页
搜索
订单
购物车
我的