npm install ramjet
, or download ramjet.js.
<div id='a' style='background-color: red; font-size: 4em; padding: 1em;'>a</div>
<div id='b' style='background-color: blue; font-size: 4em; padding: 1em;'>b</div>
<script src='ramjet.js'></script>
<script>
// to repeat, run this from the console!
ramjet.transform( a, b );
</script>
Ramjet makes it look like your DOM elements are capable of transforming into one another. It does this by cloning the elements (and all their children), transforming the second element (the one we're transforming to) so that it completely overlaps with the first, then animating the two elements together until the first element (the one we're transitioning from) has exactly the same position and dimensions as the second element originally did.
It's basically the same technique used in iOS 8 to make it appear as though each app lives inside its icon.
In modern browsers, it uses CSS animations, so everything happens off the main thread. The result is buttery-smooth performance, even on mobile devices.
a
is the DOM node we're transitioning fromb
is the DOM node we're transitioning tooptions
can include the following properties:done
- a function that gets called once the transition completesduration
- the length of the transition, in milliseconds (default 400)easing
- a function used to control the animation. Should take a number between 0 and 1, and return something similar (though it can return a number outside those bounds, if you're doing e.g. an elastic easing function). I highly recommend eases by Matt DesLauriers, which is a handy collection of these functionsuseTimer
- by default, ramjet will use CSS animations. Sometimes (when transitioning to or from SVG elements, or in very old browsers) it will fall back to timer-based animations (i.e. withrequestAnimationFrame
orsetTimeout
). If you want to always use timers, make this optiontrue
- but I don't recommend it (it's much more juddery on mobile)
Convenience function that sets the opacity of each node to 0 (temporarily disabling any transition that might otherwise interfere).
Opposite of ramjet.hide
.
A handful of easing functions, included for convenience.
Successfully tested in IE10+, Chrome (desktop and Android), Firefox, Safari 6+ and mobile Safari - please raise an issue if your experience differs! IE9 support will happen one day.
MIT.