useSeparator
Provides the accessibility implementation for a separator. A separator is a visual divider between two groups of content, e.g. groups of menu items or sections of a page.
| install | yarn add @react-aria/separator | 
|---|---|
| version | 3.0.0 | 
| usage | import {useSeparator} from '@react-aria/separator' | 
API#
useSeparator(
  (props: SeparatorProps
)): SeparatorAriaFeatures#
Horizontal separators can be built with the HTML <hr>
element. However, there is no HTML element for a vertical separator. useSeparator helps achieve
accessible separators that can be styled as needed.
- Support for horizontal and vertical orientation
- Support for HTML <hr>element or a custom element type
Anatomy#
A separator consists of a single element that represents the divider.
useSeparator returns props to be spread onto the element:
| Name | Type | Description | 
| separatorProps | HTMLAttributes<HTMLElement> | Props for the separator element. | 
Example#
This example shows how create both a horizontal and a vertical oriented separator.
function Separator(props) {
  let {separatorProps} = useSeparator(props);
  return (
    <div
      ...separatorProps
      style={
        background: 'gray'
        width: propsorientation === 'vertical' ? '1px' : '100%'
        height: propsorientation === 'vertical' ? '100%' : '1px'
        margin: propsorientation === 'vertical' ? '0 5px' : '5px 0'
      }
    />
  );
}
<>
  <div style={display: 'flex' flexDirection: 'column'}>
    Content above
    <Separator />
    Content below
  </div>
   <div
    style={
      display: 'flex'
      flexDirection: 'row'
      marginTop: 20
      height: 40
      alignItems: 'center'
    }>
    Content left
    <Separator orientation="vertical" />
    Content right
  </div>
</>function Separator(props) {
  let {separatorProps} = useSeparator(props);
  return (
    <div
      ...separatorProps
      style={
        background: 'gray'
        width:
          propsorientation === 'vertical' ? '1px' : '100%'
        height:
          propsorientation === 'vertical' ? '100%' : '1px'
        margin:
          propsorientation === 'vertical'
            ? '0 5px'
            : '5px 0'
      }
    />
  );
}
<>
  <div style={display: 'flex' flexDirection: 'column'}>
    Content above
    <Separator />
    Content below
  </div>
   <div
    style={
      display: 'flex'
      flexDirection: 'row'
      marginTop: 20
      height: 40
      alignItems: 'center'
    }>
    Content left
    <Separator orientation="vertical" />
    Content right
  </div>
</>function Separator(
  props
) {
  let {
    separatorProps
  } = useSeparator(
    props
  );
  return (
    <div
      ...separatorProps
      style={
        background:
          'gray'
        width:
          propsorientation ===
          'vertical'
            ? '1px'
            : '100%'
        height:
          propsorientation ===
          'vertical'
            ? '100%'
            : '1px'
        margin:
          propsorientation ===
          'vertical'
            ? '0 5px'
            : '5px 0'
      }
    />
  );
}
<>
  <div
    style={
      display: 'flex'
      flexDirection:
        'column'
    }>
    Content above
    <Separator />
    Content below
  </div>
   <div
    style={
      display: 'flex'
      flexDirection:
        'row'
      marginTop: 20
      height: 40
      alignItems:
        'center'
    }>
    Content left
    <Separator orientation="vertical" />
    Content right
  </div>
</>| Name | Type | Default | Description | 
| orientation | Orientation | 'horizontal' | The orientation of the separator. | 
| elementType | string | — | The HTML element type that will be used to render the separator. | 
| id | string | — | The element's unique identifier. See MDN. | 
| aria-label | string | — | Defines a string value that labels the current element. | 
| aria-labelledby | string | — | Identifies the element (or elements) that labels the current element. | 
| aria-describedby | string | — | Identifies the element (or elements) that describes the object. | 
| aria-details | string | — | Identifies the element (or elements) that provide a detailed, extended description for the object. | 
| Name | Type | Description | 
| separatorProps | HTMLAttributes<HTMLElement> | Props for the separator element. |