js拖拽的原型声明和用法总结


Posted in Javascript onApril 04, 2016

下面是自己写的一个关于js的拖拽的原型声明:代码如下

需要注意的问题包括:

1.this的指向到底是指向谁--弄清楚所指的对象

2.call()方法的使用

3.直接将父级原型赋给子级与使用for将其赋给子级有什么区别?

比如:

for(var i in Drag.prototype)
{
  LimitDrag.prototype[i]=Drag.prototype[i];----------子级发生改变,其父级并不会受到影响
}

 LimitDrag.prototype=Drag.prototype;---------直接将原型赋给子级,会导致当子级发生改变时,其父级也会随之而改变。

代码如下

<html>
<head>
<style>
#div1 {width:100px; height:100px; background:red; position:absolute;}
#div2 {width:100px; height:100px; background:yellow; position:absolute;}
</style>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>拖拽--面向对象</title>
<script>
window.onload=function()
{
  new Drag('div1');
  new LimitDrag('div2');
}
function Drag(id)
{
   var _this=this;//这个this表示p1
   this.disx=0;
   this.disy=0;
   this.oDiv=document.getElementById(id);
   this.oDiv.onmousedown=function(ev){//按下的时候有个事件,传递给下面的事件
    _this.fnDown(ev);
    return false;
   }
}; 
Drag.prototype.fnDown=function(ev)
{
    var _this=this;
    var oEvent=ev||event;
    this.disx=oEvent.clientX-this.oDiv.offsetLeft;
    this.disy=oEvent.clientY-this.oDiv.offsetTop;
    document.onmousemove=function(ev){//移动的时候有个事件
       _this.fnMove(ev);
    }
    document.onmouseup=function(){
       _this.fnUp();
    }
}; 
 Drag.prototype.fnMove=function(ev)
{
      var oEvent=ev||event;
      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;
};
//继承Drag的所有属性
function LimitDrag(id)
{
    Drag.call(this,id);//这个this指LimitDrag new的对象
}
//得到Drag的方法,遍历其原型
for(var i in Drag.prototype)
{
  LimitDrag.prototype[i]=Drag.prototype[i];
}
//改变Drag的fnMove的方法
LimitDrag.prototype.fnMove=function(ev)
{
  var oEvent=ev||event;
  var l=oEvent.clientX-this.disx;
  var t=oEvent.clientY-this.disy;
  if(l>document.documentElement.clientWidth-this.oDiv.offsetWidth)
  {
    l=document.documentElement.clientWidth-this.oDiv.offsetWidth;
  }
  else if(l<0)
  {
    l=0;
  }
   if(t>document.documentElement.clientHeight-this.oDiv.offsetHeight)
  {
    t=document.documentElement.clientHeight-this.oDiv.offsetHeight;
  }
  else if(t<0)
  {
    t=0;
  }
   this.oDiv.style.left=l+'px';
   this.oDiv.style.top=t+'px';
}
</script>
</head>
<body>
<div id="div1">
</div>
<div id="div2">
</div>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
jQuery 获取对象 基本选择与层级
May 31 Javascript
幻灯片带网页设计中的20个奇妙应用示例小结
May 27 Javascript
JQuery中使用Ajax赋值给全局变量失败异常的解决方法
Aug 18 Javascript
纯jQuery实现前端分页功能
Mar 23 jQuery
Vue之Watcher源码解析(1)
Jul 19 Javascript
javascript计算渐变颜色的实例
Sep 22 Javascript
浅谈vue项目优化之页面的按需加载(vue+webpack)
Dec 11 Javascript
angularJs复选框checkbox选中进行ng-show显示隐藏的方法
Oct 08 Javascript
Vue-cli3简单使用(图文步骤)
Apr 30 Javascript
手把手教你 CKEDITOR 4 扩展插件制作
Jun 18 Javascript
vue组件库的在线主题编辑器的实现思路
Apr 03 Javascript
jQuery实现可以计算进制转换的计算器
Oct 19 jQuery
javascript如何实现360度全景照片问题汇总
Apr 04 #Javascript
javascript制作照片墙及制作过程中出现的问题
Apr 04 #Javascript
javascript拖拽效果延伸学习
Apr 04 #Javascript
javascript事件委托的用法及其好处简析
Apr 04 #Javascript
基于javascript制作微博发布栏效果
Apr 04 #Javascript
纯js实现手风琴效果
Apr 17 #Javascript
AngularJS中的$watch(),$digest()和$apply()区分
Apr 04 #Javascript
You might like
php实现mysql数据库备份类
2008/03/20 PHP
php采用curl访问域名返回405 method not allowed提示的解决方法
2014/06/26 PHP
PHP设置Cookie的HTTPONLY属性方法
2017/02/09 PHP
PHP后台备份MySQL数据库的源码实例
2019/03/18 PHP
PHP iconv()函数字符编码转换的问题讲解
2019/03/22 PHP
JavaScript 继承使用分析
2011/05/12 Javascript
用Juery网页选项卡实现代码
2011/06/13 Javascript
jQuery setTimeout()函数使用方法
2013/04/07 Javascript
window.location.href的用法(动态输出跳转)
2014/08/09 Javascript
JavaScript设置表单上传时文件个数的方法
2015/08/11 Javascript
轻松实现js图片预览功能
2016/01/18 Javascript
javascript动画系列之模拟滚动条
2016/12/13 Javascript
jQuery实现页面滚动时智能浮动定位
2017/01/08 Javascript
ES6中Proxy代理用法实例浅析
2017/04/06 Javascript
vuejs事件中心管理组件间的通信详解
2017/08/09 Javascript
vue中使用sessionStorage记住密码功能
2018/07/24 Javascript
Vue实现远程获取路由与页面刷新导致404错误的解决
2019/01/31 Javascript
Vue.js实现开发购物车功能的方法详解
2019/02/22 Javascript
Node使用Selenium进行前端自动化操作的代码实现
2019/10/10 Javascript
解决Can't find variable: SockJS vue项目的问题
2020/09/22 Javascript
python和pygame实现简单俄罗斯方块游戏
2021/02/19 Python
python pandas模块基础学习详解
2019/07/03 Python
django做form表单的数据验证过程详解
2019/07/26 Python
PyQt 图解Qt Designer工具的使用方法
2019/08/06 Python
Python序列类型的打包和解包实例
2019/12/21 Python
python 装饰器的实际作用有哪些
2020/09/07 Python
学会迭代器设计模式,帮你大幅提升python性能
2021/01/03 Python
全球知名提供各类营养保健品的零售商:Vitamin Shoppe
2016/10/09 全球购物
一家专门做特卖的网站:唯品会
2016/10/09 全球购物
中文专业毕业生自荐信
2013/10/28 职场文书
教学质量评估实施方案
2014/03/17 职场文书
平安建设实施方案
2014/03/19 职场文书
机电一体化专业毕业生自荐信
2014/06/19 职场文书
服务整改报告
2014/11/06 职场文书
工人先锋号申报材料
2014/12/29 职场文书
股东合作协议书模板2篇
2019/11/05 职场文书