Spectrum 2 is now available! Check out the S2 Divider docs and the migration docs.

Divider

Dividers bring clarity to a layout by grouping and dividing content in close proximity. They can also be used to establish rhythm and hierarchy.

installyarn add @adobe/react-spectrum
added3.0.0
usageimport {Divider} from '@adobe/react-spectrum'

Example#


Horizontal#

View guidelines

<Flex direction="column" gap="size-125">
  <Text>Content above</Text>
  <Divider />
  <Text>Content below</Text>
</Flex>
<Flex direction="column" gap="size-125">
  <Text>Content above</Text>
  <Divider />
  <Text>Content below</Text>
</Flex>
<Flex
  direction="column"
  gap="size-125"
>
  <Text>
    Content above
  </Text>
  <Divider />
  <Text>
    Content below
  </Text>
</Flex>

Vertical#

<Flex gap="size-125">
  <Text>Content left</Text>
  <Divider orientation="vertical" />
  <Text>Content right</Text>
</Flex>
<Flex gap="size-125">
  <Text>Content left</Text>
  <Divider orientation="vertical" />
  <Text>Content right</Text>
</Flex>
<Flex gap="size-125">
  <Text>
    Content left
  </Text>
  <Divider orientation="vertical" />
  <Text>
    Content right
  </Text>
</Flex>

Size#

View guidelines

<Flex direction="column" gap="size-125">
  <Text>Content above large Divider</Text>
  <Divider size="L" />
  <Text>Content above medium Divider</Text>
  <Divider size="M" />
  <Text>Content above small Divider</Text>
  <Divider size="S" />
</Flex>
<Flex direction="column" gap="size-125">
  <Text>Content above large Divider</Text>
  <Divider size="L" />
  <Text>Content above medium Divider</Text>
  <Divider size="M" />
  <Text>Content above small Divider</Text>
  <Divider size="S" />
</Flex>
<Flex
  direction="column"
  gap="size-125"
>
  <Text>
    Content above large
    Divider
  </Text>
  <Divider size="L" />
  <Text>
    Content above
    medium Divider
  </Text>
  <Divider size="M" />
  <Text>
    Content above small
    Divider
  </Text>
  <Divider size="S" />
</Flex>

Props#


NameTypeDefaultDescription
size'S''M''L''L'How thick the Divider should be.
orientationOrientation'horizontal'The axis the Divider should align with.
Layout
NameTypeDefaultDescription
flexResponsive<stringnumberboolean>

When used in a flex layout, specifies how the element will grow or shrink to fit the space available. See MDN.

flexGrowResponsive<number>

When used in a flex layout, specifies how the element will grow to fit the space available. See MDN.

flexShrinkResponsive<number>

When used in a flex layout, specifies how the element will shrink to fit the space available. See MDN.

flexBasisResponsive<numberstring>

When used in a flex layout, specifies the initial main size of the element. See MDN.

alignSelfResponsive<'auto''normal''start''end''center''flex-start''flex-end''self-start''self-end''stretch'>

Overrides the alignItems property of a flex or grid container. See MDN.

justifySelfResponsive<'auto''normal''start''end''flex-start''flex-end''self-start''self-end''center''left''right''stretch'>

Specifies how the element is justified inside a flex or grid container. See MDN.

orderResponsive<number>

The layout order for the element within a flex or grid container. See MDN.

gridAreaResponsive<string>

When used in a grid layout, specifies the named grid area that the element should be placed in within the grid. See MDN.

gridColumnResponsive<string>

When used in a grid layout, specifies the column the element should be placed in within the grid. See MDN.

gridRowResponsive<string>

When used in a grid layout, specifies the row the element should be placed in within the grid. See MDN.

gridColumnStartResponsive<string>

When used in a grid layout, specifies the starting column to span within the grid. See MDN.

gridColumnEndResponsive<string>

When used in a grid layout, specifies the ending column to span within the grid. See MDN.

gridRowStartResponsive<string>

When used in a grid layout, specifies the starting row to span within the grid. See MDN.

gridRowEndResponsive<string>

When used in a grid layout, specifies the ending row to span within the grid. See MDN.

slotstring'divider'A slot to place the divider in.
Spacing
NameTypeDescription
marginResponsive<DimensionValue>

The margin for all four sides of the element. See MDN.

marginTopResponsive<DimensionValue>

The margin for the top side of the element. See MDN.

marginBottomResponsive<DimensionValue>

The margin for the bottom side of the element. See MDN.

marginStartResponsive<DimensionValue>

The margin for the logical start side of the element, depending on layout direction. See MDN.

marginEndResponsive<DimensionValue>

The margin for the logical end side of an element, depending on layout direction. See MDN.

marginXResponsive<DimensionValue>

The margin for both the left and right sides of the element. See MDN.

marginYResponsive<DimensionValue>

The margin for both the top and bottom sides of the element. See MDN.

Sizing
NameTypeDescription
widthResponsive<DimensionValue>The width of the element. See MDN.
minWidthResponsive<DimensionValue>

The minimum width of the element. See MDN.

maxWidthResponsive<DimensionValue>

The maximum width of the element. See MDN.

heightResponsive<DimensionValue>The height of the element. See MDN.
minHeightResponsive<DimensionValue>

The minimum height of the element. See MDN.

maxHeightResponsive<DimensionValue>

The maximum height of the element. See MDN.

Positioning
NameTypeDescription
positionResponsive<'static''relative''absolute''fixed''sticky'>

Specifies how the element is positioned. See MDN.

topResponsive<DimensionValue>

The top position for the element. See MDN.

bottomResponsive<DimensionValue>

The bottom position for the element. See MDN.

leftResponsive<DimensionValue>

The left position for the element. See MDN. Consider using start instead for RTL support.

rightResponsive<DimensionValue>

The right position for the element. See MDN. Consider using start instead for RTL support.

startResponsive<DimensionValue>

The logical start position for the element, depending on layout direction. See MDN.

endResponsive<DimensionValue>

The logical end position for the element, depending on layout direction. See MDN.

zIndexResponsive<number>

The stacking order for the element. See MDN.

isHiddenResponsive<boolean>Hides the element.
Accessibility
NameTypeDescription
idstring

The element's unique identifier. See MDN.

aria-labelstringDefines a string value that labels the current element.
aria-labelledbystringIdentifies the element (or elements) that labels the current element.
aria-describedbystringIdentifies the element (or elements) that describes the object.
aria-detailsstring

Identifies the element (or elements) that provide a detailed, extended description for the object.

Advanced
NameTypeDescription
UNSAFE_classNamestring

Sets the CSS className for the element. Only use as a last resort. Use style props instead.

UNSAFE_styleCSSProperties

Sets inline style for the element. Only use as a last resort. Use style props instead.