src/docs/transition-timing-function.mdx
import { ApiTable } from "@/components/api-table.tsx"; import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; import { Example } from "@/components/example.tsx"; import { Figure } from "@/components/figure.tsx";
export const title = "transition-timing-function"; export const description = "Utilities for controlling the easing of CSS transitions.";
<ApiTable rows={[ ["ease-linear", "transition-timing-function: linear;"], ["ease-in", "transition-timing-function: var(--ease-in); /* cubic-bezier(0.4, 0, 1, 1) /"], ["ease-out", "transition-timing-function: var(--ease-out); / cubic-bezier(0, 0, 0.2, 1) /"], ["ease-in-out", "transition-timing-function: var(--ease-in-out); / cubic-bezier(0.4, 0, 0.2, 1) */"], ["ease-initial", "transition-timing-function: initial;"], ["ease-(<custom-property>)", "transition-timing-function: var(<custom-property>);"], ["ease-[<value>]", "transition-timing-function: <value>;"], ]} />
Use utilities like ease-in and ease-out to control the easing curve of an element's transition:
<!-- [!code classes:ease-in,ease-out,ease-in-out] -->
<button class="duration-300 ease-in ...">Button A</button>
<button class="duration-300 ease-out ...">Button B</button>
<button class="duration-300 ease-in-out ...">Button C</button>
<UsingACustomValue element="button" utility="ease" value="cubic-bezier(0.95,0.05,0.795,0.035)" name="transition timing function" />
<ResponsiveDesign element="button" property="transition-timing-function" defaultClass="ease-out" featuredClass="ease-in" />
<CustomizingYourTheme element="button" utility="ease" name="transition timing function" customName="in-expo" customValue="cubic-bezier(0.95, 0.05, 0.795, 0.035)" />