src/docs/align-self.mdx
import { ApiTable } from "@/components/api-table.tsx"; import { Example } from "@/components/example.tsx"; import { Figure } from "@/components/figure.tsx"; import { ResponsiveDesign } from "@/components/content.tsx"; import { Stripes } from "@/components/stripes.tsx";
export const title = "align-self"; export const description = "Utilities for controlling how an individual flex or grid item is positioned along its container's cross axis.";
<ApiTable rows={[ ["self-auto", "align-self: auto;"], ["self-start", "align-self: flex-start;"], ["self-end", "align-self: flex-end;"], ["self-end-safe", "align-self: safe flex-end;"], ["self-center", "align-self: center;"], ["self-center-safe", "align-self: safe center;"], ["self-stretch", "align-self: stretch;"], ["self-baseline", "align-self: baseline;"], ["self-baseline-last", "align-self: last baseline;"], ]} />
Use the self-auto utility to align an item based on the value of the container's align-items property:
<!-- [!code classes:self-auto] -->
<div class="flex items-stretch ...">
<div>01</div>
<div class="self-auto ...">02</div>
<div>03</div>
</div>
Use the self-start utility to align an item to the start of the container's cross axis, despite the container's align-items value:
<!-- [!code classes:self-start] -->
<div class="flex items-stretch ...">
<div>01</div>
<div class="self-start ...">02</div>
<div>03</div>
</div>
Use the self-center utility to align an item along the center of the container's cross axis, despite the container's align-items value:
<!-- [!code classes:self-center] -->
<div class="flex items-stretch ...">
<div>01</div>
<div class="self-center ...">02</div>
<div>03</div>
</div>
Use the self-end utility to align an item to the end of the container's cross axis, despite the container's align-items value:
<!-- [!code classes:self-end] -->
<div class="flex items-stretch ...">
<div>01</div>
<div class="self-end ...">02</div>
<div>03</div>
</div>
Use the self-stretch utility to stretch an item to fill the container's cross axis, despite the container's align-items value:
<!-- [!code classes:self-stretch] -->
<div class="flex items-stretch ...">
<div>01</div>
<div class="self-stretch ...">02</div>
<div>03</div>
</div>
Use the self-baseline utility to align an item such that its baseline aligns with the baseline of the flex container's cross axis:
<!-- [!code classes:self-baseline] -->
<div class="flex ...">
<div class="self-baseline pt-2 pb-6">01</div>
<div class="self-baseline pt-8 pb-12">02</div>
<div class="self-baseline pt-12 pb-4">03</div>
</div>
Use the self-baseline-last utility to align an item along the container's cross axis such that its baseline aligns with the last baseline in the container:
<div className="font-semibold text-gray-900 sm:col-start-2 dark:text-white">Spencer Sharp</div>
<p className="self-baseline-last text-sm sm:col-start-2">
Working on the future of astronaut recruitment at Space Recruit.
</p>
<a
href="#"
className="self-baseline-last font-mono text-xs font-medium text-gray-400 underline hover:text-blue-500 dark:text-gray-500"
>
spacerecruit.com
</a>
</div>
<div className="grid grid-cols-[auto_1fr_auto] gap-x-4 px-4 py-6">
<div className="font-semibold text-gray-900 sm:col-start-2 dark:text-white">Alex Reed</div>
<p className="self-baseline-last text-sm sm:col-start-2">A multidisciplinary designer.</p>
<a
href="#"
className="self-baseline-last font-mono text-xs font-medium text-gray-400 underline hover:text-blue-500 dark:text-gray-500"
>
alex-reed.com
</a>
</div>
</div>
} </Example>
<!-- [!code classes:self-baseline-last] -->
<div class="grid grid-cols-[1fr_auto]">
<div>
<h4>Spencer Sharp</h4>
<p class="self-baseline-last">Working on the future of astronaut recruitment at Space Recruit.</p>
</div>
<p class="self-baseline-last">spacerecruit.com</p>
</div>
This is useful for ensuring that text items align with each other, even if they have different heights.