亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript反彈動畫效果的實現代碼

2019-11-19 16:05:11
字體:
來源:轉載
供稿:網友

代碼如下:

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Document</title>  <style>    #box{      width:200px;      height:200px;      position: absolute;      top:0;      left:200px;      background:lightblue;    }    .btn{      position:absolute;      top:200px;      left:100px;      height:50px;    }    .btn input{      display:inline-block;      margin-left:50px;      outline: none;      width:100px;      height:50px;      border:1px solid green;      cursor:pointer;    }  </style></head><body>  <div id='box'></div>  <div class='btn'>    <input type="button" value='向左' id='btnLeft'>    <input type="button" value='向右' id='btnRight'>  </div>  <script>    var oBox = document.getElementById("box");    var minLeft = 0;    var maxLeft = utils.win('clientWidth')-oBox.offsetWidth;    var step = 5;    var timer = null;    function move(target){      //target:告訴我要運動的目標位置      window.clearTimeout(timer);      var curLeft = utils.css(oBox,"left");      if(curLeft<target){//向右走        if(curLeft+step>target){//邊界          utils.css(oBox,"left",target);          return;        }        curLeft+=step;        utils.css(oBox,"left",curLeft)      }else if(curLeft>target){//向左走        if(curLeft-step<target){//邊界          utils.css(oBox,"left",target);          return;        }        curLeft-=step;        utils.css(oBox,"left",curLeft)      }else{//不需要運動        return;      }      // timer = window.setTimeout(move,10)//這里有一個問題,點擊按鈕第一次target的值是有的,但是第二次通過setTimeout執行的時候沒有給target進行傳值。是undefined      timer = window.setTimeout(function(){        move(target);      },10)//這樣使用匿名函數包裹一下,就解決了上面的問題,但是這樣寫性能不好,因為每一次到達時間的時候,都需要執行一次匿名函數(形成一個私有的作用域),在匿名函數中再執行move,但是move中需要用到的數據值在第一次執行的move方法中,需要把匿名函數形成的這個私有的作用域作為跳板找到之前的,這樣就導致了匿名函數形成的這個私有的作用域不能銷毀    }    document.getElementById('btnLeft').onclick = function(){      move(minLeft)    }    document.getElementById('btnRight').onclick = function(){      move(maxLeft)    }  </script></body></html>

為了解決上面性能不好的問題,下面是一個優化后的代碼:里面在使用一個函數包裹,這樣就只有move函數創建的一個私有作用域沒有銷毀,等到_move執行完畢,move就自然會進行銷毀。

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Document</title>  <style>    #box{      width:200px;      height:200px;      position: absolute;      top:0;      left:200px;      background:lightblue;    }    .btn{      position:absolute;      top:200px;      left:100px;      height:50px;    }    .btn input{      display:inline-block;      margin-left:50px;      outline: none;      width:100px;      height:50px;      border:1px solid green;      cursor:pointer;    }  </style></head><body>  <div id='box'></div>  <div class='btn'>    <input type="button" value='向左' id='btnLeft'>    <input type="button" value='向右' id='btnRight'>  </div>  <script>    var oBox = document.getElementById("box");    var minLeft = 0;    var maxLeft = utils.win('clientWidth')-oBox.offsetWidth;    var step = 5;    var timer = null;    function move(target){      //target:告訴我要運動的目標位置      _move();      function _move(){        window.clearTimeout(timer);        var curLeft = utils.css(oBox,"left");        if(curLeft<target){//向右走          if(curLeft+step>target){//邊界            utils.css(oBox,"left",target);            return;          }          curLeft+=step;          utils.css(oBox,"left",curLeft)        }else if(curLeft>target){//向左走          if(curLeft-step<target){//邊界            utils.css(oBox,"left",target);            return;          }          curLeft-=step;          utils.css(oBox,"left",curLeft)        }else{//不需要運動          return;        }        timer = window.setTimeout(_move,10);      }    }    document.getElementById('btnLeft').onclick = function(){      move(minLeft)    }    document.getElementById('btnRight').onclick = function(){      move(maxLeft)    }  </script></body></html>

注意:為了讓當前的元素在同一時間只運行一個動畫(下一個動畫開始的時候首先把上一個動畫的定時器清除掉):保證當前元素所有動畫接收定時器返回值的那個變量需要共享,有兩種方式:1、全局接收(例如上面的代碼 var timer = null)2、給元素增加自定義屬性(如下圖所示)

總結:通過以上可以得出動畫優化的四條規則:

  1、邊界判斷加步長

  2、清除沒有用的定時器

  3、在外層函數需要傳參的時候,可以在里面在嵌套一層函數,避免作用域的累積。

  4、把定時器的返回值存儲在元素的自定義屬性上,防止全局變量沖突和同一時間多個動畫執行

以上所述是小編給大家介紹的JavaScript反彈動畫效果的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线精品免播放器视频| 国产亚洲精品高潮| 欧美黑人一区二区三区| 亚洲精品成人久久| 国产午夜精品一区理论片飘花| 欧美电影免费观看高清| 亚洲第一男人av| 欧美日韩午夜视频在线观看| 91日本视频在线| 亚洲欧美日韩爽爽影院| 国产精品一区二区3区| 久久久久久久影院| 91亚洲精品视频| 日韩有码视频在线| 国产精品美女www| 国产精品最新在线观看| 黑人巨大精品欧美一区二区一视频| 亚洲aⅴ日韩av电影在线观看| 久久91精品国产91久久跳| 性欧美办公室18xxxxhd| 亚洲精品一区久久久久久| 88国产精品欧美一区二区三区| 亚洲已满18点击进入在线看片| 国产视频丨精品|在线观看| 国产男女猛烈无遮挡91| 日韩在线观看免费高清完整版| 92国产精品久久久久首页| 亚州精品天堂中文字幕| 国产成人亚洲综合| 成人免费网视频| 亚洲伊人一本大道中文字幕| 日韩欧美亚洲一二三区| 色青青草原桃花久久综合| 狠狠操狠狠色综合网| 国产啪精品视频网站| 欧美激情精品久久久久| 九九视频这里只有精品| 一区二区三区 在线观看视| 久久香蕉频线观| 亚洲一区二区久久| 97超级碰在线看视频免费在线看| 日韩电影第一页| 欧美自拍视频在线| 中文欧美在线视频| 国产精品永久免费在线| 91av在线影院| www.欧美免费| 国产在线播放91| 精品国产一区二区三区久久久| 国a精品视频大全| 欧美日韩国产成人在线观看| 亚洲一区二区中文| 一本色道久久综合狠狠躁篇怎么玩| 欧美激情免费在线| 日韩中文字幕网址| 久久久久久中文| 日韩欧美国产免费播放| 日韩av中文字幕在线免费观看| 亚洲一区二区在线| 亚洲毛片在线观看| 成人免费网站在线| 国产精品露脸自拍| 欧美国产日韩一区二区三区| 欧美日韩一区二区三区在线免费观看| 亚洲免费视频在线观看| 国产精品久久av| 亚洲成人久久久久| 国色天香2019中文字幕在线观看| 亚洲欧美精品在线| 日韩欧美国产激情| 国产精品一区二区电影| 亚洲精品免费av| 日韩免费观看高清| 欧美中文字幕精品| 日韩亚洲第一页| 亚洲精品短视频| 国产精品免费久久久久久| 久久影院资源站| 一本一本久久a久久精品牛牛影视| 中文字幕不卡av| 国产成人精品综合| 夜夜躁日日躁狠狠久久88av| 日韩毛片在线观看| 亚洲美女中文字幕| 亚洲精品永久免费| 精品国产精品三级精品av网址| 精品国产美女在线| 国产精品久久久久91| 亚洲成人av资源网| 国产精品免费视频久久久| 91久久在线视频| 日韩电影中文字幕在线观看| 欧美尺度大的性做爰视频| 97av在线视频| 欧美性高潮床叫视频| 久久精品国产69国产精品亚洲| 欧美午夜女人视频在线| 色偷偷噜噜噜亚洲男人| 国产欧美一区二区三区久久人妖| 亚洲国产成人精品女人久久久| 欧美在线视频免费观看| 欧美午夜性色大片在线观看| 青青久久aⅴ北条麻妃| 91沈先生在线观看| 亚洲尤物视频网| 欧美亚洲在线观看| 欧美激情精品久久久久久变态| 欧美自拍大量在线观看| 日韩欧美福利视频| 日本91av在线播放| 亚洲成人久久一区| 国产精品影片在线观看| 国产精品18久久久久久麻辣| 国产精品成人免费电影| 少妇高潮久久77777| 热99精品里视频精品| 国产九九精品视频| 国产精品精品国产| 日韩精品久久久久久福利| 久久久精品久久久| 欧美成人免费网| 中文字幕一区二区三区电影| 欧美一级免费视频| 亚洲一区二区三区视频播放| 一区二区欧美激情| 亚洲成色www8888| 亚洲区中文字幕| 国产在线精品自拍| 国产精品福利观看| 九色精品免费永久在线| 亚洲成人精品av| 日韩成人中文字幕在线观看| 久久精品青青大伊人av| 第一福利永久视频精品| 亚洲免费伊人电影在线观看av| 亚洲福利视频网| 久久国产精品视频| 国产精品久久久久久久久久久久久| 亚洲午夜色婷婷在线| 欧美亚洲成人xxx| 亚洲人成网站免费播放| 日韩一二三在线视频播| 两个人的视频www国产精品| 中文字幕国产亚洲| 亚洲网站在线观看| 精品性高朝久久久久久久| 久久久久久999| 激情久久av一区av二区av三区| 日韩理论片久久| 精品国产成人在线| 日本久久久久久久久| 91精品国产综合久久香蕉的用户体验| 国产精品自拍视频| 亚洲精品乱码久久久久久按摩观| 日韩一区二区精品视频| 欧美电影在线免费观看网站| 久久久亚洲国产天美传媒修理工| 欧美在线精品免播放器视频| 久久久久亚洲精品| 日本一区二区三区四区视频| 国产成人精品一区二区在线| 欧美一级视频在线观看| 午夜精品国产精品大乳美女| 亚洲第一级黄色片|