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

JS實現(xiàn)多物體運動的方法詳解

 更新時間:2018年01月23日 12:27:06   作者:關(guān)耳佳  
這篇文章主要介紹了JS實現(xiàn)多物體運動的方法,結(jié)合實例形式較為詳細的分析了javascript實現(xiàn)多物體運動的原理與相關(guān)操作技巧,需要的朋友可以參考下

本文實例分析了JS實現(xiàn)多物體運動的方法。分享給大家供大家參考,具體如下:

基本步驟

1.通過getElementsByTagName獲取到要做多物體運動的元素
2.然后for循環(huán)遍歷元素,添加事件
3.定義startMove函數(shù),需要兩個參數(shù),當前“做運動”的元素,和目標值target

注意問題:在多物體運動中,所有的東西不能公用;

<script>
    window.onload = function(){
      var liTags = document.getElementsByTagName('li'); // 第一步
      for(var i=0;i<liTags.length;i++){ // 第二步
         liTags[i].onmouseover = function () {
         startMove(this,400);
         }
         liTags[i].onmouseout = function () {
         startMove(this,200);
         }
      }
    }
    var timer = null;
    function startMove(obj,iTarget) { // 第三步,2個參數(shù)
      clearInterval(timer);
      timer = setInterval(function () {
        var iSpeed = (iTarget - obj.offsetWidth)/10;
        iSpeed = iSpeed>0 ?Math.ceil(iSpeed):Math.floor(iSpeed);// 緩沖運動注意取整處理
        if(obj.offsetWidth == iTarget){
          clearInterval(timer);
        }else{
          obj.style.width = obj.offsetWidth+iSpeed+'px';
        }
      },30);
    }
</script>

問題:

當移入移出速度比較快的時候,就會出現(xiàn)有的li回不到原來的樣子,卡在半路了;這是因為所有的li公用了一個定時器造成的;

當鼠標移入第一個li時,調(diào)用startMove開啟一個定時器;鼠標移除li時,也需要開啟一個定時器讓li回到原來的位置,li走到半路上,我們移入第二個li,首先會清除定時器,這時候第一個li就卡到半路了。

解決這個問題:讓每個li擁有自己的timer去控制他們的變化,在for循環(huán)的時候,給每個里定義自己的一個timer

liTags[i].timer = null;// 給每個li都添加一個timer

接著在starMove里面每次用的定時器都是當前l(fā)i 自己的,就不會互相干擾了。

這里由之前的timer變成了obj.timer (當前對象自己的timer);到這里就沒問題了。

完整代碼如下:

<body>
<ul>
  <li></li>
  <li></li>
  <li></li>
  <li></li>
</ul>
</body>

加點樣式:

<style>
    ul{list-style: none;}
    ul li{
      margin: 10px;
      width: 200px;height: 50px;
      background: lightblue;
    }
</style>

完整js代碼

<script>
    window.onload = function(){
      var liTags = document.getElementsByTagName('li');
      for(var i=0;i<liTags.length;i++){
         liTags[i].timer = null;// 給每個li都添加一個timer
         liTags[i].onmouseover = function () {
         startMove(this,400);
         }
         liTags[i].onmouseout = function () {
         startMove(this,200);
         }
      }
    }
    function startMove(obj,iTarget) {
      clearInterval(obj.timer);
      obj.timer = setInterval(function () {
        var iSpeed = (iTarget - obj.offsetWidth)/10;
        iSpeed = iSpeed>0 ?Math.ceil(iSpeed):Math.floor(iSpeed);
        if(obj.offsetWidth == iTarget){
          clearInterval(obj.timer);
        }else{
          obj.style.width = obj.offsetWidth+iSpeed+'px';
        }
      },30);
    }
</script>

接著在看一個例子:多物體運動-改變透明度

<script>
  window.onload = function () {
    var aImgs = document.getElementsByTagName('img');
    for(var i=0;i<aImgs.length;i++){
      aImgs[i].timer = null;
      aImgs[i].alpha = 100; // 把公用的alpha改成每個img對象都有的屬性
      aImgs[i].onmouseover = function () {
        startMove(this,30);
      }
      aImgs[i].onmouseout = function () {
        startMove(this,100);
      }
    }
  }
  // var alpha = 100; 這里alpha在多物體運動里 不能公用
  function startMove(obj,iTarget) {
    clearInterval(obj.timer);
    var iSpeed = (iTarget - obj.alpha)/10;
      iSpeed = iSpeed>0 ? Math.ceil(iSpeed): Math.floor(iSpeed);
    obj.timer = setInterval(function(){
      if(obj.alpha == iTarget){
        clearInterval(obj.timer);
      }else{
        obj.alpha += iSpeed;
        obj.style.opacity =obj.alpha/100;
        obj.style.filter = 'alpha(opacity:'+obj.alpha+')';
      }
    },30);
  }
</script>

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript運動效果與技巧匯總》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

  • js改變img標簽的src屬性在IE下沒反應(yīng)的解決方法

    js改變img標簽的src屬性在IE下沒反應(yīng)的解決方法

    在Chrome FF里都能改變成功,但在IE下卻不行,網(wǎng)上搜了半天,大概了解了,這個是IE的一個bug,具體的解決方法如下,有類似問題的朋友可以參考下哈,希望對大家有所幫助
    2013-07-07
  • 取消Bootstrap的dropdown-menu點擊默認關(guān)閉事件方法

    取消Bootstrap的dropdown-menu點擊默認關(guān)閉事件方法

    今天小編就為大家分享一篇取消Bootstrap的dropdown-menu點擊默認關(guān)閉事件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Webpack中的文件指紋的實現(xiàn)

    Webpack中的文件指紋的實現(xiàn)

    本文主要介紹了Webpack中的文件指紋的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-01-01
  • JavaScript實用技巧(一)

    JavaScript實用技巧(一)

    本文從7個方面講述 JavaScript 中那些你不很熟知但非常實用的技巧。
    2010-08-08
  • 一文詳解DOM的概念和常用操作

    一文詳解DOM的概念和常用操作

    本文詳細介紹了DOM的概念和常用操作,文檔對象模型 (DOM) 是 HTML 和 XML 文檔的編程接口。它提供了對文檔的結(jié)構(gòu)化的表述,并定義了一種方式可以使從程序中對該結(jié)構(gòu)進行訪問,從而改變文檔的結(jié)構(gòu),樣式和內(nèi)容,感興趣的朋友可以參考閱讀本文
    2023-04-04
  • js特殊字符過濾的示例代碼

    js特殊字符過濾的示例代碼

    本篇文章主要是對js特殊字符過濾的示例代碼進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-03-03
  • JavaScript引用類型RegExp基本用法詳解

    JavaScript引用類型RegExp基本用法詳解

    這篇文章主要介紹了JavaScript引用類型RegExp基本用法,結(jié)合實例形式較為詳細的分析了引用類型RegExp正則表達式相關(guān)函數(shù)使用技巧與操作注意事項,需要的朋友可以參考下
    2018-08-08
  • JavaScript 異步調(diào)用

    JavaScript 異步調(diào)用

    本文通過一個小小題目逐步走進javascript 異步調(diào)用問題,本文附有解答過程,感興趣的朋友一起看看吧
    2017-10-10
  • JS實現(xiàn)定時自動關(guān)閉DIV層提示框的方法

    JS實現(xiàn)定時自動關(guān)閉DIV層提示框的方法

    這篇文章主要介紹了JS實現(xiàn)定時自動關(guān)閉DIV層提示框的方法,可實現(xiàn)加載時載入js代碼控制div層提示框自動關(guān)閉的效果,非常簡單實用,需要的朋友可以參考下
    2015-05-05
  • 淺談JS繼承_寄生式繼承 & 寄生組合式繼承

    淺談JS繼承_寄生式繼承 & 寄生組合式繼承

    下面小編就為大家?guī)硪黄獪\談JS繼承_寄生式繼承 & 寄生組合式繼承。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08

最新評論