48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
| import getRequestAnimationFrame, { cancelRequestAnimationFrame } from '../_util/getRequestAnimationFrame'
 | |
| 
 | |
| const reqAnimFrame = getRequestAnimationFrame()
 | |
| 
 | |
| export default function throttleByAnimationFrame (fn) {
 | |
|   let requestId
 | |
| 
 | |
|   const later = args => () => {
 | |
|     requestId = null
 | |
|     fn(...args)
 | |
|   }
 | |
| 
 | |
|   const throttled = (...args) => {
 | |
|     if (requestId == null) {
 | |
|       requestId = reqAnimFrame(later(args))
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   throttled.cancel = () => cancelRequestAnimationFrame(requestId)
 | |
| 
 | |
|   return throttled
 | |
| }
 | |
| 
 | |
| export function throttleByAnimationFrameDecorator () {
 | |
|   return function (target, key, descriptor) {
 | |
|     const fn = descriptor.value
 | |
|     let definingProperty = false
 | |
|     return {
 | |
|       configurable: true,
 | |
|       get () {
 | |
|         if (definingProperty || this === target.prototype || this.hasOwnProperty(key)) {
 | |
|           return fn
 | |
|         }
 | |
| 
 | |
|         const boundFn = throttleByAnimationFrame(fn.bind(this))
 | |
|         definingProperty = true
 | |
|         Object.defineProperty(this, key, {
 | |
|           value: boundFn,
 | |
|           configurable: true,
 | |
|           writable: true,
 | |
|         })
 | |
|         definingProperty = false
 | |
|         return boundFn
 | |
|       },
 | |
|     }
 | |
|   }
 | |
| }
 |