gsap-performance
greensock/gsap-skills
Optimize GSAP animations for 60fps—prefer transforms, batch operations, and avoid layout thrashing.
What is gsap-performance?
Official GSAP skill for performance optimization. Use when animating with GSAP and need to reduce jank, improve frame rates, or follow best practices for smooth animations. Covers transform/opacity preference, will-change usage, batching, stagger, quickTo, and ScrollTrigger optimization.
- Prefer animating transform (x, y, scale, rotation) and opacity to keep work on the compositor
- Avoid layout-heavy properties (width, height, top, left, margin, padding) that trigger reflows
- Use will-change CSS hint to promote layers for animating elements
- Batch DOM reads and writes to prevent layout thrashing
- Use stagger for efficient multi-element animations instead of manual delays
- Apply gsap.quickTo() for frequently updated properties like mouse followers
How to install gsap-performance
npx skills add https://github.com/greensock/gsap-skills --skill gsap-performanceHow to use gsap-performance
- 1.Identify animations using layout-heavy properties (width, height, top, left) and replace with transform-based alternatives (x, y, scale)
- 2.Add will-change: transform to CSS for elements that will be animated
- 3.Replace multiple tweens with manual delays using stagger for the same animation across elements
- 4.For frequently updated properties, use gsap.quickTo() instead of creating new tweens each update
- 5.Batch DOM reads before writes to avoid layout thrashing when mixing GSAP with direct DOM manipulation
- 6.Debounce ScrollTrigger.refresh() calls and only refresh when layout actually changes
- 7.Test animations on low-end devices and kill or pause off-screen animations to reduce simultaneous work
Use cases
- Reducing jank and frame drops in complex GSAP animations
- Optimizing mouse-follower or cursor-tracking animations with quickTo()
- Improving performance of staggered animations across many elements
- Tuning ScrollTrigger animations for smooth scroll performance on low-end devices
- Cleaning up off-screen animations to prevent background performance drain
- Frontend developers optimizing animation performance
- Web developers working with GSAP on performance-critical projects
- Developers building scroll-triggered or interactive animations
- Teams targeting 60fps on mobile and low-end devices
gsap-performance FAQ
No. Use will-change only on elements that are actually animating. Setting it on every element wastes resources and can hurt performance.
GSAP's x and y use CSS transforms (translate), which are compositor-friendly and avoid layout. left/top trigger layout recalculations and cause jank. Prefer x/y for movement.
Use quickTo() for properties updated frequently (e.g., mouse followers, drag interactions). It reuses a single tween instead of creating new ones on each update, improving efficiency.
Pin only what's needed, use scrub with small values (e.g., scrub: 1), and call ScrollTrigger.refresh() only when layout changes—debounce if needed. Test on low-end devices.
Pause or kill animations that are not visible to the user. This prevents unnecessary work and improves overall page performance.
Full instructions (SKILL.md)
Source of truth, from greensock/gsap-skills.
name: gsap-performance description: Official GSAP skill for performance — prefer transforms, avoid layout thrashing, will-change, batching. Use when optimizing GSAP animations, reducing jank, or when the user asks about animation performance, FPS, or smooth 60fps. license: MIT
GSAP Performance
When to Use This Skill
Apply when optimizing GSAP animations for smooth 60fps, reducing layout/paint cost, or when the user asks about performance, jank, or best practices for fast animations.
Related skills: Build animations with gsap-core (transforms, autoAlpha) and gsap-timeline; for ScrollTrigger performance see gsap-scrolltrigger.
Prefer Transform and Opacity
Animating transform (x, y, scaleX, scaleY, rotation, rotationX, rotationY, skewX, skewY) and opacity keeps work on the compositor and avoids layout and most paint. Avoid animating layout-heavy properties when a transform can achieve the same effect.
- ✅ Prefer: x, y, scale, rotation, opacity.
- ❌ Avoid when possible: width, height, top, left, margin, padding (they trigger layout and can cause jank).
GSAP’s x and y use transforms (translate) by default; use them instead of left/top for movement.
will-change
Use will-change in CSS on elements that will animate. It hints the browser to promote the layer.
will-change: transform;
Batch Reads and Writes
GSAP batches updates internally. When mixing GSAP with direct DOM reads/writes or layout-dependent code, avoid interleaving reads and writes in a way that causes repeated layout thrashing. Prefer doing all reads first, then all writes (or let GSAP handle the writes in one go).
Many Elements (Stagger, Lists)
- Use stagger instead of many separate tweens with manual delays when the animation is the same; it’s more efficient.
- For long lists, consider virtualization or animating only visible items; avoid creating hundreds of simultaneous tweens if it causes jank.
- Reuse timelines where possible; avoid creating new timelines every frame.
Frequently updated properties (e.g. mouse followers)
Prefer gsap.quickTo() for properties that are updated often (e.g. mouse-follower x/y). It reuses a single tween instead of creating new tweens on each update.
let xTo = gsap.quickTo("#id", "x", { duration: 0.4, ease: "power3" }),
yTo = gsap.quickTo("#id", "y", { duration: 0.4, ease: "power3" });
document.querySelector("#container").addEventListener("mousemove", (e) => {
xTo(e.pageX);
yTo(e.pageY);
});
ScrollTrigger and Performance
- pin: true promotes the pinned element; pin only what’s needed.
- scrub with a small value (e.g.
scrub: 1) can reduce work during scroll; test on low-end devices. - Call ScrollTrigger.refresh() only when layout actually changes (e.g. after content load), not on every resize; debounce when possible.
Reduce Simultaneous Work
- Pause or kill off-screen or inactive animations when they’re not visible (e.g. when the user navigates away).
- Avoid animating huge numbers of properties on many elements at once; simplify or sequence if needed.
Best practices
- ✅ Animate transform and opacity; use will-change in CSS only on elements that animate.
- ✅ Use stagger instead of many separate tweens with manual delays when the animation is the same.
- ✅ Use gsap.quickTo() for frequently updated properties (e.g. mouse followers).
- ✅ Clean up or kill off-screen animations; call ScrollTrigger.refresh() when layout changes, debounced when possible.
Do Not
- ❌ Animate width/ height/ top/ left for movement when x/ y/ scale can achieve the same look.
- ❌ Set will-change or force3D on every element “just in case”; use for elements that are actually animating.
- ❌ Create hundreds of overlapping tweens or ScrollTriggers without testing on low-end devices.
- ❌ Ignore cleanup; stray tweens and ScrollTriggers keep running and can hurt performance and correctness.
Related skills
More from greensock/gsap-skills and the wider catalog.
gsap-core
Official GSAP core API for JavaScript animations — tweens, easing, stagger, and responsive animation.
gsap-scrolltrigger
Official GSAP plugin for scroll-linked animations, pinning, and scrubbing.
gsap-timeline
Sequence and choreograph multi-step animations with GSAP timelines, position parameters, and nested playback control.
gsap-plugins
Official GSAP plugins for animations—scroll, drag, flip layouts, text effects, SVG, and easing.
gsap-utils
Official GSAP utility functions for math, value mapping, randomization, and array handling in animations.
gsap-react
Official GSAP hook and patterns for smooth animations in React and Next.js.