v4.4.0
- Transforms
- Transforms now follow a fixed render order (
perspective>translate>rotate>scale>skew), regardless of the order they are defined in animation parameters:// Before: scale rendered first because it was defined first animate(el, { scale: 2, translateX: 100 }) // → scale(2) translateX(100px) // After: order is always fixed animate(el, { scale: 2, translateX: 100 }) // → translate(100px, 0px) scale(2)
matrixandmatrix3dcan no longer be animated directly (they are still preserved when read from inline styles and can be set using transform: 'matrix(...)')
- Transforms now follow a fixed render order (
- Function-based values
- The third argument of function-based value callbacks changed from
total(Number) totargets(Array). To migrate, replacetotalwithtargets.length:// Before translateX: (target, index, total) => total * 10 // After translateX: (target, index, targets) => targets.length * 10
- A fourth argument
prevTweenis now passed to function-based value callbacks, providing access to the previous sibling tween's computed end value for the same target and property.
- The third argument of function-based value callbacks changed from
- Stagger
- The stagger callback signature changed to match function-based values: the third argument is now the
targetsarray instead of the total count:// Before delay: stagger(100, { use: (target, i, total) => total - i }) // After delay: stagger(100, { use: (target, i, targets) => targets.length - i })
- The stagger callback signature changed to match function-based values: the third argument is now the
- scrambleText
- New
scrambleText()function-based value to animate text with a character-by-character scramble/reveal effect (learn more: https://animejs.com/documentation/text/scrambletext)
- New
- Stagger
- New
grid: trueauto-grid mode that computes a 2D layout from element positions or JS object coordinates ({x, y}) instead of requiring explicit[columns, rows]dimensions - The
fromparameter now accepts[x, y]normalized coordinate arrays (0 to 1) for precise grid origin control
- New
- Timer / Animation / Timeline
- New
priorityparameter to control execution order within the engine tick loop
- New
- Transforms
- Adjacent axis properties are now grouped into CSS shorthand for shorter transform strings:
translateX+translateY→translate(x, y)translateX+translateY+translateZ→translate3d(x, y, z)scaleX+scaleY→scale(x, y)scaleX+scaleY+scaleZ→scale3d(x, y, z)
- Inline transform parsing rewritten to properly handle multi-argument CSS functions (
translate(x, y),scale3d(x, y, z)) and nestedcalc()expressions
- Adjacent axis properties are now grouped into CSS shorthand for shorter transform strings:
- Layout
createLayout()now accepts anidparameter
- Exports
globalsis now exported from the main module entry pointforEachChildren,addChild,removeChildhelpers are now exported fromutils
- JS Animation
revert()now restores object properties and DOM attributes to their original pre-animation values, in addition to CSS styles and transforms (previously only CSS styles and transforms were reverted, leaving animated object props and attributes at their last animated value). The publiccleanInlineStyles()utility keeps its original behavior and only clears inline styles and transforms.- Fix
getOriginalAnimatableValuenot storing the original inline value for object properties and DOM attributes, preventing proper revert
- morphTo
- Fix chaining in keyframe arrays and timelines producing incorrect intermediate shapes
- Chainable utils
- Fix accessing non-existent chainable methods throwing an error instead of returning
undefined
- Fix accessing non-existent chainable methods throwing an error instead of returning
- splitText
- Fix
addEffect()returningundefinedinstead ofthiswhen the effect argument is not a function
- Fix
- Layout
- Fix scroll-controlled layout animations not properly calling
onCompleteandonPausecallbacks
- Fix scroll-controlled layout animations not properly calling
- keepTime
- Fix
_startTimenot being preserved when reconstructing tracked animations, causing timing jumps on effect refresh
- Fix
- Engine
- DevTools integration (
AnimeJSDevTools) removed - Render loop performance: inline closures in
tick()andrender()extracted to module-scope functions to avoid allocation every frame - Tween composition is now resolved before computing
to/from/duration/delayvalues, so the previous sibling tween is available to function-based value callbacks
- DevTools integration (
- splitText
- Type annotation for
splitText()andTextSplittertarget parameter widened fromHTMLElementtoElement
- Type annotation for
- Tween value chaining
- Each tween now pre-computes and stores its end value at construction time
- Enables function-based values like
morphToandscrambleTextto read the previous tween's end value when used in keyframe arrays or timelines
- morphTo
- Now properly chains in keyframe arrays and timelines by reading the previous tween's computed end value instead of mutating the target element with a Symbol
- Editor integration (👀)
- New
globals.editorhook system allowing an external editor to interceptanimate()andcreateTimeline()calls
- New
v4.3.3
-
Refresh
- Function-based "from" values now refresh correctly when calling
.refresh() - Unit conversion (e.g.,
svhtorem) is recalculated on refresh
- Function-based "from" values now refresh correctly when calling
-
onScroll
- Add
onResizecallback that triggers when the scroll container refreshes due to a resize event
- Add
-
Playback
- Add missing
tl.backward/anim.backward/time.backwardproperty doc
- Add missing
-
Easing
- Add an opacity animation preview to the easing functions editor
v4.3.0
- AutoLayout
- New
createLayout()method to easily animate between two layout states (learn more about layouts here: https://animejs.com/documentation/layout)
- New
- Easings
- The
easeparameter now accepts function-based values (likedurationanddelayproperties)
- The
- Timeline
- Add
compositionparameter to disable animation composition when using.add()and greatly improve performance
- Add
- JS Animation
- Fix an issue where complex values containing a color (e.g.,
box-shadow) would be incorrectly handled as color values instead of complex string values
- Fix an issue where complex values containing a color (e.g.,
- WAAPI
- Fix animations not being properly removed from
document.timelinein some cases
- Fix animations not being properly removed from
- Draggable
- Fix spring parameters not properly setting the duration
- Timeline
- Fix spring easing being ignored when defined in the
defaultsparameter - Fix
.call()and.sync()incorrectly inheritingdelayfromdefaultsparameters
- Fix spring easing being ignored when defined in the
- splitText
- Fix a bug where the first word of the second line could be incorrectly added to the first line
- Fix unnecessary empty spaces not being properly removed from lines
- Engine
- Increase max fps to 240 (previously 120)
- Animation / Timer / Timeline
- Add
muteCallbacksparameter to.complete(muteCallbacks)to complete the animation without triggering callbacks