码迷,mamicode.com
首页 > 其他好文 > 详细

缓动函数requestAnimationFrame用法

时间:2016-04-01 00:55:58      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:

 

 // shim layer with setTimeout fallback
window.requestAnimFrame = (function(){
  return  window.requestAnimationFrame ||
    window.webkitRequestAnimationFrame ||
 

   window.mozRequestAnimationFrame ||
    window.oRequestAnimationFrame ||
    window.msRequestAnimationFrame ||
    function(/* function FrameRequestCallback */ callback, /* DOMElement Element */ element){
    window.setTimeout(callback, 1000 / 60);
  };


})();

具体这是什么 有什么好处 请找度娘 大致就是无限setTimeout 的递归套

我只做个简单的demo

<!DOCTYPE html>
<html>
<meta charset="utf-8" content="text/html">
<head>
    <title></title>
</head>
<body>
    <div id="div1" style="width: 100px; height: 100px; background: red; color:#fff ;position: absolute; left: 0; top: 0;">
        
        点我停下来
    </div>


<script type="text/javascript">
         // shim layer with setTimeout fallback
window.requestAnimFrame = (function(){
        return  window.requestAnimationFrame ||
          window.webkitRequestAnimationFrame ||
          window.mozRequestAnimationFrame ||
          window.oRequestAnimationFrame ||
          window.msRequestAnimationFrame ||
          function(/* function FrameRequestCallback */ callback, /* DOMElement Element */ element){
          window.setTimeout(callback, 1000 / 60);
        };
})();

var Animate=false;

var x=0;

//普通递归
    // feiris();
    // function feiris(){
    //                 if(Animate){return false;}
    //                 x++;
    //                 document.getElementById("div1").style.left=x+"px";
                    
    //                 setTimeout(function(){
                                                
    //                         feiris();
                         
    //                 },16);
    // };
//利用缓动
 function autoMove() {
     x++;
     document.getElementById("div1").style.left=x+"px";
}

(function animloop(){
     autoMove();
     if(!Animate){requestAnimFrame(animloop);}//elem没有用
})();
document.getElementById("div1").onclick=function(){
            
             Animate=true;
            
}

</script>
</body>

</html>

 然后各位可以chrome对比性能

缓动函数requestAnimationFrame用法

标签:

原文地址:http://www.cnblogs.com/lanbosm/p/5343350.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!