Before Knowing about framer motion first we should know why should we need Framer motion? Framer motion improves upon and simplifies the API in a way that couldn't have been done without breaking changes and rewriting. As a react developer, I found it very exciting as I can create animations using technologies that I’m already familiar with.
What is Framer Motion?
Framer Motion is a production-ready motion library to create animations using React. It brings declarative animations, effortless layout transitions, and gestures while maintaining HTML and SVG semantics.
How to use Framer Motion in our Project
Install framer motion using in your project using
npm install framer-motion
Remember one thing Framer-Motion requires that you are using React version 16.8 or higher.
Once installed, you can import Motion into your components via framer-motion.
import { motion } from "framer-motion"
That’s it. Now you are able to use framer-motion in your Project. Let's see basic syntaxes of Framer Motion with few examples.
Animation
Animations are driven by Framer Motion’s versatile animate prop. It can cater to the very simplest, and most advanced use-cases.
Motion components are one of the core elements in Framer Motion, and most animations in Framer Motion are controlled via the motion component’s flexible animate property.*
Depending on your requirements, you can use the animate property in a variety of ways:
<motion.div animate={{ x: 200,rotate:180 }} />
In the above example, the div tag will move 200px to the right and rotate 180 degrees.
Transition
This transition can be optionally configured using Popmotion’s familiar tween, spring, and inertia animations.
Physical properties like x and scale are animated via spring by default, while values like opacity and color are animated with a tween. You can also use the transition prop to change properties like duration, delay, and stiffness of the animation.
<motion.div animate={{ x: 200,rotate:180 }}
transition={{ duration: 2, repeat: Infinity }} />
In the above example, the div tag will move 200px to the right and rotate 180 degrees. the duration and repeat props are used to keep that animation in a loop with a duration of 2 seconds.
Keyframes
Values in animate can also be set as a series of keyframes. This will animate through each value in a sequence. By default, a keyframes animation will start with the first item in the array.
<motion.div animate={{ scale: [2, 2, 1] }} />
In the above example, div will scale through each value in the sequence.
Variants
Variants are a collection of pre-defined target objects passed into motion components by using the variants prop. Target objects are useful for simple, single-component animations. But sometimes we want to create animations that propagate throughout the DOM and orchestrate those animations in a declarative way.
By defining variants on a set of components, providing a variant label to animate will propagate this animation through all the children like additional transition props such as when, delayChildren, and staggerChildren.
import * as React from "react";
import { motion } from "framer-motion";
const variants = {
open: {
transition: { staggerChildren: 0.09, delayChildren: 0.3 }
},
closed: {
transition: { staggerChildren: 0.06, staggerDirection: -1 }
}
};
export const Navigation = () => (
<motion.ul variants={variants}>
{itemIds.map(i => (
<MenuItem i={i} key={i} />
))}
</motion.ul>
);
const itemIds = [ 1, 2, 3, 4];
In the above example, staggerChildren and delayChildren props are used to delay the transition of the menu items. In addition, the staggerDirection prop is used to specify the direction of the stagger.
Gestures
Motion extends the basic set of event listeners provided by React with a simple yet powerful set of UI gesture recognizers. It currently has support for hover, tap, pan, and drag gesture detection. Each gesture has a series of event listeners that you can attach to your motion component.
Hover
The hover gesture detects when a pointer hovers over or leaves a component. There are three hover props available — whileHover, onHoverStart(event, info), and onHoverEnd(event, info).
<motion.div
whileHover={{ scale: 1.2 }}
onHoverStart={() => console.log("starts")}
onHoverEnd={() => console.log("ends")}
/>
n the above example, when we will hover over the div its size will increase and when we start hovering in the console it will print 'start', and when we stop hovering it will print 'end'.
Focus
The focus gesture detects when a component gains or loses focus through a click, focus, or by tabindex. the focus prop is whileFocus.
<motion.div
whileFocus={{ scale: 1.5 }}
/>
In the above example, when we will focus on the div its size will increase.
Tap
The tap gesture detects when a pointer presses down and releases on the same component.
There are three hover props available — whiletap,onTap(event,info),onTapStart(event, info),onTapCancel(event, info)
<motion.div whileTap={{ scale: 1.2 }} />
In the above example, when we will Tap on the div its size will increase.
Pan
The pan gesture recognizes when a pointer presses down on a component and moves further than 3 pixels. The pan gesture is ended when the pointer is released.
There are three hover props available — onPanStart,onPan,onPanEnd
For pan gestures to work correctly with touch input, the element needs touch scrolling to be disabled on either x/y or both axis with the touch-action CSS rule
function onPan(event, info) {
console.log(info.point.x, info.point.y)
}
<motion.div onPan={onPan} />
In the above example, A Info object containing x and y values for point is relative to the device or page. delta is Distance moved since the last event. offset is Offset from the original pan event. velocity is the Current velocity of the pointer.
Drag
The drag gesture follows the rules of the pan gesture but applies pointer movement to the x and/or y-axis of the component.
<motion.div
drag
dragTransition={{
min: 0,
max: 100,
bounceStiffness: 100
}}
>
Drag
</motion.div>
In the above example, dragging is enable for both x-direction and y-directions. If you want to limit it only to the x-direction, you can set the drag property value to “x”: drag=“x”.
Hopefully, It helps you to start using framer motion in your React project for building some really cool animations. If any queries regarding this write them down in the comment below. Thank you for your time and I hoped my blog is helpful for you.
Happy Learning!!
Top comments (5)
Nice explanation.
Will be better if you have showcases for each one.
Thank you 😊
Keep up the good work, waiting for more
Showcases would've been perfect :)
I so wanted this lib for #Angular