Introducing PrimeReact v11-alpha 🎉Discover Now

useDivider

Headless hook for building content separators with custom markup.

Fast setup, no credit card required.

Cancel anytime from your account.

basic-demo

Usage#

import { useDivider } from '@primereact/headless/divider';
const { rootProps } = useDivider({ orientation: 'horizontal' });
 
return <div {...rootProps} role="separator" />;

useDivider returns spread-ready rootProps with orientation and alignment data attributes so you can style horizontal and vertical separators with pure CSS. See Primitive for a component-based API.

Features#

  • Orientation awareness — orientation drives both aria-orientation and data-orientation on the root
  • Alignment data — align writes a data-align attribute you can target from CSS for content placement
  • Stateless — no internal state or effects; markup and styling are entirely yours
  • Markup-agnostic — works with any block element that accepts standard props

Working with callbacks#

Vertical separator#

Switch orientation to "vertical" when separating inline content such as toolbar items.

const { rootProps } = useDivider({ orientation: 'vertical' });
 
<div {...rootProps} role="separator" />;

Divider with label#

Provide align to position label content inside the divider, then render the text as a child.

const { rootProps } = useDivider({ align: 'center' });
 
<div {...rootProps} role="separator">
    <span>OR</span>
</div>;

Styling with data attributes#

Use data-orientation and data-align to branch styles without conditional class logic.

[data-scope='divider'][data-part='root'] {
    border-top: 1px solid #e5e7eb;
}
[data-scope='divider'][data-orientation='vertical'] {
    width: 1px;
    align-self: stretch;
}
[data-scope='divider'][data-align='center'] {
    text-align: center;
}

API#

useDivider#

NameTypeDefault
align"center" | "top" | "bottom" | "left" | "right"—
Alignment of the content.
orientation"horizontal" | "vertical"horizontal
Specifies the orientation, valid values are 'horizontal' and 'vertical'.
type"solid" | "dashed" | "dotted"solid
Border style type.

Accessibility#

Announced as a separator via the ARIA role, otherwise non-interactive. See Primitive for full WAI-ARIA compliance details.