猿问
原生js一般是如何实现运动效果的?
我移动端一般就是用css3的动画,pc端都是用jq那几个常用动画就没用过其他的了,想问下大家用原生js实现运动效果都是怎么实现的?会不会很麻烦或者用什么库吗?
慕侠2389804
浏览 598
回答 1
1回答
POPMUISE
一般是:setInterval(function(){ //dosomething...},1000/60);或者:window.requestAnimationFrame(function(/* time */ time){ // time ~= +new Date // the unix time});或者:// shim layer with setTimeout fallbackwindow.requestAnimFrame = (function(){ return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function( callback ){ window.setTimeout(callback, 1000 / 60); }; })();// usage:// instead of setInterval(render, 16) ....(function animloop(){ requestAnimFrame(animloop); render(); })();// place the rAF *before* the render() to assure as close to// 60fps with the setTimeout fallback.或者(更牢靠的封装):(function() { var lastTime = 0; var vendors = ['webkit', 'moz']; for(var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { window.requestAnimationFrame = window[vendors[x]+'RequestAnimationFrame']; window.cancelAnimationFrame = window[vendors[x]+'CancelAnimationFrame'] || window[vendors[x]+'CancelRequestAnimationFrame']; } if (!window.requestAnimationFrame) window.requestAnimationFrame = function(callback, element) { var currTime = new Date().getTime(); var timeToCall = Math.max(0, 16 - (currTime - lastTime)); var id = window.setTimeout(function() { callback(currTime + timeToCall); }, timeToCall); lastTime = currTime + timeToCall; return id; }; if (!window.cancelAnimationFrame) window.cancelAnimationFrame = function(id) { clearTimeout(id); }; }());
0
0
0
随时随地看视频
慕课网APP
相关分类
JavaScript
我要回答