成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端小白用面向?qū)ο笏枷雽崿F(xiàn)元素拖拽

springDevBird / 1150人閱讀

摘要:上篇文章分享了如何用面向?qū)ο笏枷刖帉戇x項卡,在文章最后留了一個拖拽的例子,希望大家可以試著寫一下,現(xiàn)在我就談談我在這過程中遇到的一些問題和解決方法。通過以上方法來訓練面向?qū)ο蟮木幊趟枷?,多練習,以后寫出面向?qū)ο笏枷氲拇a就很簡單了。

上篇文章分享了如何用面向?qū)ο笏枷刖帉戇x項卡,在文章最后留了一個拖拽的例子,希望大家可以試著寫一下,現(xiàn)在我就談談我在這過程中遇到的一些問題和解決方法。(本文主要是想和js初學者分享經(jīng)驗,代碼中的更改this指向,事件綁定均采用的比較初級的方法,也希望能有大神能指導,分享一下經(jīng)驗)。

現(xiàn)在我們來看看面向過程式的編程的代碼,HTML只有一個div元素,設置寬高和背景顏色。

#div1{
            width: 100px;
            height: 100px;
            background: red;
            position: absolute;
        }

    
window.onload=function(){ var oDiv=document.getElementById("div1"); var disX=0; var disY=0; oDiv.onmousedown=function(ev){ var ev=ev || window.event; disX=ev.clientX-oDiv.offsetLeft; disY=ev.clientY-oDiv.offsetTop; document.onmousemove=function(ev){ var ev=ev || window.event; oDiv.style.left=ev.clientX-disX+"px"; oDiv.style.top=ev.clientY-disY+"px"; }; document.onmouseup=function(){ document.onmousemove=null; document.onmouseup=null; } return false; } }

還是用上一篇文章提到的方法,先將變量和方法提取出來,不要出現(xiàn)函數(shù)的嵌套,出現(xiàn)嵌套的將其中的函數(shù)提取出來。變量為oDiv,disX和disY,我將代碼中的三個事件綁定的函數(shù)命名為fnDown,fnMove,fnUp,因此將上面的代碼改為如下格式:

var oDiv,disX,disY;
        window.onload=function(){
            oDiv=document.getElementById("div1");
            
            disX=0;
            disY=0;
            oDiv.onmousedown=fnDown();
        }
        
        
        function fnDown(ev){
            var ev=ev || window.event;
            disX=ev.clientX-oDiv.offsetLeft;
            disY=ev.clientY-oDiv.offsetTop;
            document.onmousemove=fnMove();
            document.onmouseup=fnUp();
            return false;
        }
        function fnMove=function(ev){
                var ev=ev || window.event;
                oDiv.style.left=ev.clientX-disX+"px";
                oDiv.style.top=ev.clientY-disY+"px";
            };
        function fnUp=function(){
                document.onmousemove=null;
                document.onmouseup=null;
            }

然后用面向?qū)ο蟮乃枷雽傩院头椒ㄌ砑拥綄ο笾校⒃趯傩院头椒ㄇ懊婕由蟭his,因此改變的代碼如下:

window.onload=function(){
        var d1=new Drag("div1");
        d1.init();
    };
    function Drag(id){
        this.oDiv=document.getElementById(id);
        this.disX=0;
        this.disY=0;
    };
    Drag.prototype.init=function(){
        this.oDiv.onmousedown=this.fnDowm();
    };
    Drag.prototype.fnDowm=function(ev){
        var ev=ev || window.event;
        this.disX=ev.clientX-this.oDiv.offsetLeft;
        this.disY=ev.clientY-this.oDiv.offsetTop;
        document.onmousemove=this.fnMove();
        document.onmouseup=this.fnUp();
        return false;
    };

    Drag.prototype.fnMove=function(ev){
        var ev || window.event;
        this.oDiv.style.left=ev.clientX-this.disX+"px";
        this.oDiv.style.top=ev.clientY-this.disY+"px";
    };

    Drag.prototype.fnMove=function(){
        document.onmousemove=null;
        document.onmouseup=null;
    };

和前面一樣,找出其中this的指向錯誤并改正。但是除了this指向問題,上面還有一個關于事件的問題。document.onmousemove=this.fnMove();,向這樣在事件上添加方法的方式是不正確的,正確的調(diào)用方式是這樣:document.onmousemove=function(ev){};,因此將方法改為以下形式。

Drag.prototype.init=function(){
            
            this.oDiv.onmousedown=function(ev){
                var ev=ev || window.event;
                this.fnDown(ev);
                return false;
            };
        };

        Drag.prototype.fnDown = function(ev){
            
            this.disX = ev.clientX - this.oDiv.offsetLeft;
            this.disY = ev.clientY - this.oDiv.offsetTop;
                
            document.onmousemove = function(ev){
                var ev = ev || window.event;
                this.fnMove(ev);
            };
            document.onmouseup=function(){
                this.fnUp();
            }
        };


        Drag.prototype.fnMove=function(ev){
            
            this.oDiv.style.left=ev.clientX-this.disX+"px";
            this.oDiv.style.top=ev.clientY-this.disY+"px";
        };
        
        Drag.prototype.fnUp=function(){
            document.onmousemove=null;
            document.onmouseup=null;
        };

最后要找到錯誤的this指向,并改正。關于this指向,我認為最簡單的方法就是看函數(shù)是怎么調(diào)用的,函數(shù)名 "." 左邊的就是this的指向。下面我們來舉個例子:

Drag.prototype.init=function(){
            
            this.oDiv.onmousedown=function(ev){
                var ev=ev || window.event;
                this.fnDown(ev);
                return false;
            };
        };

原型上面的init()方法的調(diào)用方式是d1.init(),因此函數(shù)內(nèi)的this指向就是d1,那么this.oDiv指向就是正確的,但是onmouseover()的調(diào)用方式是this.oDiv.onmousedown,其內(nèi)部this指向就是this.oDiv,而在該函數(shù)內(nèi)部,this.fnDown(ev)語句this指向是oDiv,而oDiv是沒有方法和屬性的,因此這里的this指向就是錯誤的,需要修正。
下面的幾個方法中this也這來來分析,并將其改為正確的指向。修改this的指向還是和上一篇修改的方法一樣。因此改完后代碼為:

window.onload=function(){

            var d1=new Drag("div1");
            d1.init();

        };

        function Drag(id){
            this.oDiv=document.getElementById(id);
            this.disX=0;
            this.disY=0;
        }
        Drag.prototype.init=function(){
            var This=this;
            this.oDiv.onmousedown=function(ev){
                var ev=ev || window.event;
                This.fnDown(ev);
                return false;
            };
        };

        Drag.prototype.fnDown = function(ev){
            var This = this;
            this.disX = ev.clientX - this.oDiv.offsetLeft;
            this.disY = ev.clientY - this.oDiv.offsetTop;
                
            document.onmousemove = function(ev){
                var ev = ev || window.event;
                This.fnMove(ev);
            };
            document.onmouseup=function(){
                This.fnUp();
            }
        };


        Drag.prototype.fnMove=function(ev){
            
            this.oDiv.style.left=ev.clientX-this.disX+"px";
            this.oDiv.style.top=ev.clientY-this.disY+"px";
        };
        
        Drag.prototype.fnUp=function(){
            document.onmousemove=null;
            document.onmouseup=null;
        };

這樣就可以正常運行了。

作為一名小白,就應該多動腦,多動手。在這過程中你會學到很多。通過以上方法來訓練面向?qū)ο蟮木幊趟枷耄嗑毩?,以后寫出面向?qū)ο笏枷氲拇a就很簡單了。

因為以上代碼也是我通過看視頻學的,所以還有點疑問,希望有人能解答一下。上面只有onmousedown時間是綁定在oDiv上,后面的時間都是綁定在document上,我試著將后面的事件也綁定在oDiv中,程序也能運行,但是快速拖動就會產(chǎn)生停頓的問題,而在document上就沒有類似的情況,這是為什么?

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/82399.html

相關文章

  • 前端小白如何面向對象思想寫代碼

    摘要:根據(jù)以上代碼的變形,我們現(xiàn)在用面向?qū)ο笏枷雭砭帉懘a,創(chuàng)建構造函數(shù),添加屬性及方法。首先構造函數(shù)中的,由于是用關鍵字,因此指向,沒問題。同時將指向當前點擊的以參數(shù)形式傳入中,這樣一個面向?qū)ο笏枷氲拇a就寫出來了。 ??本人自學前端近半年,js達到熟練的水平,面向?qū)ο笏枷搿his指向有一定的了解,但是要用面向?qū)ο笏枷雽懘a就一臉懵逼了,最近看到某課堂的視頻(里面廣告嫌疑,就不說是啥了)...

    Guakin_Huang 評論0 收藏0
  • 前端基礎進階(十):面向對象實戰(zhàn)之封裝拖拽對象

    摘要:前面幾篇文章,我跟大家分享了的一些基礎知識,這篇文章,將會進入第一個實戰(zhàn)環(huán)節(jié)利用前面幾章的所涉及到的知識,封裝一個拖拽對象。不封裝對象直接實現(xiàn)利用原生封裝拖拽對象通過擴展來實現(xiàn)拖拽對象。 showImg(https://segmentfault.com/img/remote/1460000008699587); 前面幾篇文章,我跟大家分享了JavaScript的一些基礎知識,這篇文章,...

    Eidesen 評論0 收藏0
  • 【連載】前端個人文章整理-從基礎到入門

    摘要:個人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個目錄,方便更多的小伙伴去學習。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個人前端文章整理 從最開始萌生寫文章的想法,到著手...

    madthumb 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<