欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript 多物體運動的實現(xiàn)

 更新時間:2014年12月24日 16:04:05   投稿:hebedich  
這篇文章主要介紹了Javascript 多物體運動的實現(xiàn),需要的朋友可以參考下

我們先來看下之前的運動的代碼,是否支持多物體運動,會出現(xiàn)怎么樣的問題。

復(fù)制代碼 代碼如下:

<style type="text/css">
            div {
                width: 100px;
                height: 50px;
                background: red;
                margin: 10px;
            }
        </style>

復(fù)制代碼 代碼如下:

<body>
        <div></div>
        <div></div>
        <div></div>
    </body>

以下是Javascript 代碼:

復(fù)制代碼 代碼如下:

<script type="text/javascript">
            window.onload = function() {
                var aDiv = document.getElementsByTagName('div');
                for (var i = 0; i < aDiv.length; i++) {
                    aDiv[i].onmouseover = function() {
                        startMove(this, 400);
                    };
                    aDiv[i].onmouseout = function() {
                        startMove(this, 100);
                    };
                }
            }
            var timer = null;
            function startMove(obj, iTarget) {
                clearInterval(timer);
                timer = setInterval(function() {
                    var speed = (iTarget - obj.offsetWidth) / 6;
                    speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
                    if (obj.offsetWidth == iTarget) {
                        clearInterval(timer);
                    } else {
                        obj.style.width = obj.offsetWidth + speed + 'px';
                    }
                }, 30);
            }
        </script>

此時當鼠標移入到第一個div 時,他是正常運行的。但是如果現(xiàn)在又移動到第二個或者第三個div時候就會出現(xiàn)bug。

image 這個是什么原因呢? 看圖可以看出并沒有運動完成。實際上是這樣的,

整個程序就一個定時器, 比如第一個div開始動了,第二個div 鼠標移入了 前一個定時器就被干掉了,那么自然就卡在那里了。

所以最大的問題就是整個程序就只有一個定時器。那么怎么解決這個問題呢?

解決方案:

其實很簡單,把定時器作為一個物體的屬性加上,那么每個物體都有一個定時器在,當關(guān)閉定時器的時候是關(guān)閉物體上的定時器,開也是物體上的定時器

那么他們之間就可以完全互不干擾的運行。

看下修改后的Javascript代碼:

復(fù)制代碼 代碼如下:

<script type="text/javascript">
            window.onload = function() {
                var aDiv = document.getElementsByTagName('div');
                for (var i = 0; i < aDiv.length; i++) {
                    aDiv[i].timer=null; // 把定時器作為一個物體的屬性存起來
                    aDiv[i].onmouseover = function() {
                        startMove(this, 400);
                    };
                    aDiv[i].onmouseout = function() {
                        startMove(this, 100);
                    };
                }
            }
            function startMove(obj, iTarget) {
                clearInterval(obj.timer);
                obj.timer = setInterval(function() {
                    var speed = (iTarget - obj.offsetWidth) / 6;
                    speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
                    if (obj.offsetWidth == iTarget) {
                        clearInterval(obj.timer);
                    } else {
                        obj.style.width = obj.offsetWidth + speed + 'px';
                    }
                }, 30);
            }
        </script>

這樣程序就沒有問題了,能夠支持多物體的運動。

相關(guān)文章

  • js中動態(tài)創(chuàng)建json,動態(tài)為json添加屬性、屬性值的實例

    js中動態(tài)創(chuàng)建json,動態(tài)為json添加屬性、屬性值的實例

    下面小編就為大家?guī)硪黄猨s中動態(tài)創(chuàng)建json,動態(tài)為json添加屬性、屬性值的實例。小編覺的挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • JS實現(xiàn)商品倒計時實現(xiàn)代碼

    JS實現(xiàn)商品倒計時實現(xiàn)代碼

    JS實現(xiàn)商品倒計時實現(xiàn)代碼,需要的朋友可以參考一下
    2013-05-05
  • JS中產(chǎn)生標識符方式的演變

    JS中產(chǎn)生標識符方式的演變

    本文記錄下JS中產(chǎn)生標識符方式的演變,從ES5到ES6,ES5及其之前是一種方式,只包含兩種聲明(var/function),ES6則增加了一些產(chǎn)生標識符的關(guān)鍵字,如 let、const、class。
    2015-06-06
  • 小程序云開發(fā)初探(小結(jié))

    小程序云開發(fā)初探(小結(jié))

    云開發(fā)是微信平臺新開放的功能,為開發(fā)者提供集成了服務(wù)器,數(shù)據(jù)庫和資源存儲的云服務(wù)。這篇文章主要介紹了小程序云開發(fā)初探(小結(jié)),感興趣的小伙伴們可以參考一下
    2018-10-10
  • js中Array.sort()利用零值多維排序

    js中Array.sort()利用零值多維排序

    本文主要介紹了js中Array.sort()利用零值多維排序,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2023-05-05
  • 微信小程序引入Vant組件庫過程解析

    微信小程序引入Vant組件庫過程解析

    這篇文章主要介紹了微信小程序引入Vant組件庫過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2019-08-08
  • 微信小程序分享功能onShareAppMessage(options)用法分析

    微信小程序分享功能onShareAppMessage(options)用法分析

    這篇文章主要介紹了微信小程序分享功能onShareAppMessage(options)用法,結(jié)合具體實例形式分析了微信小程序分享功能onShareAppMessage(options)具體使用技巧與相關(guān)操作注意事項,需要的朋友可以參考下
    2019-04-04
  • Wordpress ThickBox 添加“查看原圖”效果代碼

    Wordpress ThickBox 添加“查看原圖”效果代碼

    上一次修改了點擊圖片動作 , 這次添加一個“查看原圖”的鏈接,點擊后將在一個新瀏覽器窗口(或Tab)打開該圖片的原始鏈接地址。
    2010-12-12
  • 利用10行js代碼實現(xiàn)上下滾動公告效果

    利用10行js代碼實現(xiàn)上下滾動公告效果

    這篇文章主要給大家介紹了關(guān)于利用10行js代碼實現(xiàn)滾動公告效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起看看吧。
    2017-12-12
  • js 彈出對話框(遮罩)透明,可拖動的簡單實例

    js 彈出對話框(遮罩)透明,可拖動的簡單實例

    下面小編就為大家?guī)硪黄猨s 彈出對話框(遮罩)透明,可拖動的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07

最新評論