let lastTime = 0; const prefixes = 'webkit moz ms o'.split(' '); // 各浏览器前缀 let requestAnimationFrame; let cancelAnimationFrame; const isServer = typeof window === 'undefined'; if (isServer) { requestAnimationFrame = function() { return; }; cancelAnimationFrame = function() { return; }; } else { requestAnimationFrame = window.requestAnimationFrame; cancelAnimationFrame = window.cancelAnimationFrame; let prefix; // 通过遍历各浏览器前缀,来得到requestAnimationFrame和cancelAnimationFrame在当前浏览器的实现形式 for (let i = 0; i < prefixes.length; i++) { if (requestAnimationFrame && cancelAnimationFrame) { break; } prefix = prefixes[i]; requestAnimationFrame = requestAnimationFrame || window[prefix + 'RequestAnimationFrame']; cancelAnimationFrame = cancelAnimationFrame || window[prefix + 'CancelAnimationFrame'] || window[prefix + 'CancelRequestAnimationFrame']; } // 如果当前浏览器不支持requestAnimationFrame和cancelAnimationFrame,则会退到setTimeout if (!requestAnimationFrame || !cancelAnimationFrame) { requestAnimationFrame = function(callback) { const currTime = new Date().getTime(); // 为了使setTimteout的尽可能的接近每秒60帧的效果 const timeToCall = Math.max(0, 16 - (currTime - lastTime)); const id = window.setTimeout(() => { callback(currTime + timeToCall); }, timeToCall); lastTime = currTime + timeToCall; return id; }; cancelAnimationFrame = function(id) { window.clearTimeout(id); }; } } export { requestAnimationFrame, cancelAnimationFrame };