This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2020.
The getKeyframes() method of a KeyframeEffect returns an Array of the computed keyframes that make up this animation along with their computed offsets.
getKeyframes()
None.
Returns a sequence of objects with the following format:
As many property value pairs as are contained in each keyframe of the animation.
offsetThe offset of the keyframe specified as a number between 0.0 and 1.0 inclusive or null. This is equivalent to specifying start and end states in percentages in CSS stylesheets using @keyframes. This will be null if the keyframe is automatically spaced.
computedOffsetThe computed offset for this keyframe, calculated when the list of computed keyframes was produced. Unlike offset above, the computedOffset is never null.
easingThe easing function used from this keyframe until the next keyframe in the series.
compositeThe KeyframeEffect.composite operation used to combine the values specified in this keyframe with the underlying value. This will be absent if the composite operation specified on the effect is being used.
In the following example, we can inspect the rolling animation to see its keyframes using the getKeyframes() method:
const emoji = document.querySelector("div"); // element to animate
const rollingKeyframes = new KeyframeEffect(
emoji,
[
{ transform: "translateX(0) rotate(0)" }, // keyframe
{ transform: "translateX(200px) rotate(1.3turn)" }, // keyframe
],
{
// keyframe options
duration: 2000,
direction: "alternate",
easing: "ease-in-out",
iterations: "Infinity",
},
);
const rollingAnimation = new Animation(rollingKeyframes, document.timeline);
rollingAnimation.play();
// Array [ {…}, {…} ]
console.log(rollingAnimation.effect.getKeyframes());
<div>🤣</div>
| Specification |
|---|
| Web Animations> # dom-keyframeeffect-getkeyframes> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
getKeyframes |
84 | 84 | 63 | 71 | 13.1 | 84 | 63 | 60 | 13.4 | 14.0 | 84 | 13.4 |
KeyframeEffect objects.
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/KeyframeEffect/getKeyframes