tempus
means time in Latin, this package is a lightweight, high-performance animation frame manager for JavaScript applications.
- 🚀 Merge multiple requestAnimationFrame loops for better performance
- 🎯 Control execution priority of different animations
- ⚡ Support for custom frame rates (FPS)
- 🔄 Compatible with popular animation libraries
- 🪶 Zero dependencies
- 📦 ~1KB gzipped
using package manager
npm install tempus
import Tempus from 'tempus'
using script tag
<script src="https://unpkg.com/tempus@1.0.0-dev.9/dist/tempus.min.js"></script>
import Tempus from "tempus"
// Simple animation at maximum FPS
function animate(time, deltaTime) {
console.log('frame', time, deltaTime)
}
Tempus.add(animate)
const unsubscribe = Tempus.add(animate)
unsubscribe()
See tempus/react
Tempus.add(animate, {
fps: 30 // Will run at 30 FPS
})
// Higher priority (runs first)
Tempus.add(criticalAnimation, { priority: -1 })
// Lower priority (runs after)
Tempus.add(secondaryAnimation)
// Patch native requestAnimationFrame across all your app
Tempus.patch()
// Now any requestAnimationFrame recursive calls will use Tempus
Tempus.add(lenis.raf)
// Remove GSAP's internal RAF
gsap.ticker.remove(gsap.updateRoot)
// Add to Tempus
Tempus.add((time) => {
gsap.updateRoot(time / 1000)
})
Tempus.add(() => {
renderer.render(scene, camera)
}, { priority: 1 })
// the render will happen after other rafs
// so it can be synched with lenis for instance
Adds an animation callback to the loop.
- callback:
(time: number, deltaTime: number) => void
- options:
priority
:number
(default: 0) - Lower numbers run firstfps
:number
(default: Infinity) - Target frame rate
- Returns:
() => void
- Unsubscribe function
Patches the native requestAnimationFrame
to use Tempus.
- Use priorities wisely: critical animations (like scroll) should have higher priority
- Clean up animations when they're no longer needed
- Consider using specific FPS for non-critical animations to improve performance (e.g: collisions)
MIT © darkroom.engineering
Thank you to Keith Cirkel for having transfered us the npm package name 🙏.