45 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
| const availablePrefixs = ['moz', 'ms', 'webkit']
 | |
| 
 | |
| function requestAnimationFramePolyfill () {
 | |
|   let lastTime = 0
 | |
|   return function (callback) {
 | |
|     const currTime = new Date().getTime()
 | |
|     const timeToCall = Math.max(0, 16 - (currTime - lastTime))
 | |
|     const id = window.setTimeout(function () { callback(currTime + timeToCall) }, timeToCall)
 | |
|     lastTime = currTime + timeToCall
 | |
|     return id
 | |
|   }
 | |
| }
 | |
| 
 | |
| export default function getRequestAnimationFrame () {
 | |
|   if (typeof window === 'undefined') {
 | |
|     return () => {}
 | |
|   }
 | |
|   if (window.requestAnimationFrame) {
 | |
|     // https://github.com/vuejs/vue/issues/4465
 | |
|     return window.requestAnimationFrame.bind(window)
 | |
|   }
 | |
| 
 | |
|   const prefix = availablePrefixs.filter(key => `${key}RequestAnimationFrame` in window)[0]
 | |
| 
 | |
|   return prefix
 | |
|     ? window[`${prefix}RequestAnimationFrame`]
 | |
|     : requestAnimationFramePolyfill()
 | |
| }
 | |
| 
 | |
| export function cancelRequestAnimationFrame (id) {
 | |
|   if (typeof window === 'undefined') {
 | |
|     return null
 | |
|   }
 | |
|   if (window.cancelAnimationFrame) {
 | |
|     return window.cancelAnimationFrame(id)
 | |
|   }
 | |
|   const prefix = availablePrefixs.filter(key =>
 | |
|     `${key}CancelAnimationFrame` in window || `${key}CancelRequestAnimationFrame` in window,
 | |
|   )[0]
 | |
| 
 | |
|   return prefix
 | |
|     ? (window[`${prefix}CancelAnimationFrame`] || window[`${prefix}CancelRequestAnimationFrame`]).call(this, id)
 | |
|     : clearTimeout(id)
 | |
| }
 |