47 lines
1.6 KiB
JavaScript
47 lines
1.6 KiB
JavaScript
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 }
|