React Transition Switch provides a simple and effective way to easily switch between different components with CSS animations. It's perfect for creating interactive and visually appealing transitions in your React applications.
npm install react-transition-switch
This package provides a TransitionSwitch
parent component and a TransitionSwitchItem
child component.
- The
TransitionSwitch
component accepts avalue
prop, and children which can beTransitionSwitchItem
components. Components other thanTransitionSwitchItem
are not affected by thevalue
prop. - The
TransitionSwitchItem
component also accepts avalue
prop, and a child which must be a component that accepts a ref, or an element such as a div. If its value matches the parent's value, only this item's children will be rendered.
import { useState } from 'react';
import {
TransitionSwitch,
TransitionSwitchItem,
} from 'react-transition-switch';
const MyComponent = () => {
const [value, setValue] = useState('item1');
return (
<TransitionSwitch value={value}>
<TransitionSwitchItem value='item1'>
<div>Item 1</div>
</TransitionSwitchItem>
<TransitionSwitchItem value='item2'>
<div>Item 2</div>
</TransitionSwitchItem>
{/* Add more TransitionSwitchItems as needed */}
</TransitionSwitch>
);
};
To add transitions between items, you can use CSS animations. Simply add a CSS class to your parent TransitionSwitch
component:
<TransitionSwitch value={value} className='fade'>
<TransitionSwitchItem value='item1'>
<div>Item 1</div>
</TransitionSwitchItem>
</TransitionSwitch>
In your CSS file, define your animations for active/incoming and inactive/outgoing items, and add them to the correct children by their data-state
attribute.
CSS example
.fade {
position: relative;
}
.fade > * {
position: absolute;
inset-block-start: 0;
inset-inline-start: 0;
}
.fade > [data-state='active'] {
animation: fadeIn 300ms cubic-bezier(0.4, 0, 0.2, 1);
}
.fade > [data-state='inactive'] {
animation: fadeOut 300ms cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes fadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
@keyframes fadeOut {
from {
opacity: 1;
}
to {
opacity: 0;
}
}
Prop | Type | Description |
---|---|---|
asChild |
boolean |
Change the default <div> element for the one passed as a child, merging their props and behavior.When set to true, this component must have a single child which accepts a ref, and its children should be <TransitionSwitchItem> components.See Radix UI composition |
autoAdjustHeight |
boolean |
Whether or not the parent container should automatically adjust its height to that of the active child. |
autoAdjustWidth |
boolean |
Whether or not the parent container should automatically adjust its width to that of the active child. |
directional |
boolean |
Add a data-direction attribute to the parent element, representing the transition direction, which would have a value of either 'backward' or 'forward'. This allows to apply a different animation based on the transition direction. |