vant/src/utils/dom/raf.ts
2020-09-28 17:48:07 +08:00

37 lines
756 B
TypeScript

/**
* requestAnimationFrame polyfill
*/
import { inBrowser } from '../base';
let prev = Date.now();
function fallback(fn: FrameRequestCallback): number {
const curr = Date.now();
const ms = Math.max(0, 16 - (curr - prev));
const id = setTimeout(fn, ms);
prev = curr + ms;
return id;
}
const root = (inBrowser ? window : global) as Window;
const iRaf = root.requestAnimationFrame || fallback;
const iCancel = root.cancelAnimationFrame || root.clearTimeout;
export function raf(fn: FrameRequestCallback): number {
return iRaf.call(root, fn);
}
// double raf for animation
export function doubleRaf(fn: FrameRequestCallback): void {
raf(() => {
raf(fn);
});
}
export function cancelRaf(id: number) {
iCancel.call(root, id);
}