美文网首页JavaScript学习笔记
关于为多个DIV加拖拽里面this的问题

关于为多个DIV加拖拽里面this的问题

作者: lemontree2000 | 来源:发表于2016-11-07 00:01 被阅读0次

关于调试

话说一个程序员的调试能力可体现出他的整体素质。所以我要养成好的调试习惯,减少在调试上花的时间。

解决问题

今天在为多个div加拖拽时发现无法运行程序,于是开始分析。首先在没有看出代码明显错误的情况下我就从基本的代码开始排查。先看控制台是否报错,这时我的控制报,没有style属性。按照以往的经验一般是对象的问题,于是使用alert();的方法, 先从获取元素开始,经排查发现元素获取正确,然后排查onmousedown 事件, 将alert放入事件末尾发现还是能执行。 在排查onmousemove时发现alert已经不执行了。说明果然是对象的问题,因为这里写着改Left 和top 的代码,是用的this.style.left; 也就是说我的this用的有问题,当时我就alert(this);弹出 [object HTMLDocument] 这里的this指向document,因为我是用的document.onmousemove .所以是document事件的this。所以要想代码执行起来必须解决this的问题。 一开始我就想能不能将div循环里aDiv[i]放到这里来,试了一下结果不行,然后机开始想办法将onmousedown的this如何用到onmousemove来。 这是想到可以定义一个变量因为onmousemove是onmousedown子函数所以在副函数定义变量子函数是可以获取的, 这就是闭包。于是我就定义了 _this = this . onmousemove 里就用_this ,结果就可以运行了。 代码如下:

window.onload = function () {
        var aDiv = document.body.getElementsByTagName('div');   
        
        for (var i = 0; i < aDiv.length; i++){
            aDiv[i].onmousedown = function(ev) {
                var oEvent = ev || event;
                var disX = oEvent.clientX - this.offsetLeft;
                var disY = oEvent.clientY - this.offsetTop;
                var _this = this;  // 定义一个变量来接收 这里的this
                document.onmousemove = function(ev){
                    var oEvent = ev || event;
                    l = oEvent.clientX - disX;
                    t = oEvent.clientY - disY;
                    _this.style.left = l + 'px'; // 引用鼠标按下里面的this
                    _this.style.top = t + 'px'; // 引用鼠标按下里面的this
                    //alert(this); //[  object HTMLDocument]
                };
                document.onmouseup = function () {
                    document.onmousemove = document.onmouseup = null;
                    _this.releaseCaptrue && _this.releaseCaptrue(); 
                };
                _this.setCaptrue && _this.setCaptrue();
                return false;
            };
            
            
        }
    };

end

相关文章

  • 关于为多个DIV加拖拽里面this的问题

    关于调试 话说一个程序员的调试能力可体现出他的整体素质。所以我要养成好的调试习惯,减少在调试上花的时间。 解决问题...

  • 事件应用

    拖拽 拖拽原理 三大事件 -鼠标和Div的相对距离不变 把拖拽加到document上 如果拖得太快,会移出div,...

  • 事件应用

    拖拽 拖拽原理 三大事件 -鼠标和Div的相对距离不变 把拖拽加到document上 如果拖得太快,会移出div,...

  • div 拖拽

    /* 图标功能加载*/pageCommon.nav = function () {var posX;var pos...

  • JavaScript--拖拽原理

    拖拽雏形:html+css 代码: 问题:如果鼠标拖的快点,会发现鼠标从div出去后,这个时候div不会跟着鼠标走...

  • 拖拽div的值到table

    Html 代码 jQeruyUI拖拽效果_拖拽div的值到table表格...

  • inline-block布局的怪异现象

    同事刚刚遇到一个关于css display:"inline-block"的怪异问题,div下面有多个并列的 ,当其...

  • 禁止ios浏览器页面滚动的橡皮筋效果

    问题:在做手机端,通过拖拽调整某个div大小时,拖拽引起了整体页面的弹动 方法一:通过css设置body宽高htm...

  • submit3快捷键

    Submit3快捷键 html:xt快速生成默认html模板 快速创建多个div div>div*3外面一个里面...

  • js 元素添加父元素

    以多个video分别添加父元素div为例

网友评论

    本文标题:关于为多个DIV加拖拽里面this的问题

    本文链接:https://www.haomeiwen.com/subject/mrbnuttx.html