Build faster with Premium Chakra UI Components 💎

Learn more
Skip to Content
DocsPlaygroundGuidesBlog
Sponsor

Select (Native)

Used to pick a value from predefined options.

SourceStorybookRecipe

Setup

If you don't already have the snippet, run the following command to add the native-select snippet

npx @chakra-ui/cli snippet add native-select

The snippet includes a closed component composition for the NativeSelect component.

Usage

import {
  NativeSelectField,
  NativeSelectRoot,
} from "@/components/ui/native-select"
<NativeSelectRoot>
  <NativeSelectField>
    <option value="1">Option 1</option>
    <option value="2">Option 2</option>
  </NativeSelectField>
</NativeSelectRoot>

Examples

Sizes

Use the size prop to change the size of the select component.

Variants

Use the variant prop to change the appearance of the select component.

Items Prop

Pass the items prop to the NativeSelectField component to render a list of options.

Controlled

Use the value and onChange props to control the select component.

Disabled

Pass the disabled prop to the NativeSelectRoot component to disable the select component.

Invalid

Compose the native and Field component to set the invalid set and show the error text.

This is an error

Alternatively, you can use the invalid prop on the NativeSelectRoot component as well.

Hook Form

Here is an example of how to use the NativeSelect component with react-hook-form.

Ref

Here's how to access the underlying element reference

const Demo = () => {
  const ref = useRef<HTMLSelectElement | null>(null)
  return (
    <NativeSelectRoot>
      <NativeSelectField ref={ref}>
        <option value="1">Option 1</option>
        <option value="2">Option 2</option>
      </NativeSelectField>
    </NativeSelectRoot>
  )
}

Props

Root

PropDefaultType
colorPalette 'gray'
'gray' | 'red' | 'orange' | 'yellow' | 'green' | 'teal' | 'blue' | 'cyan' | 'purple' | 'pink' | 'accent'

The color palette of the component

variant 'outline'
'outline' | 'filled' | 'plain'

The variant of the component

size 'md'
'lg' | 'md' | 'sm' | 'xs'

The size of the component

as
React.ElementType

The underlying element to render.

asChild
boolean

Use the provided child element as the default rendered element, combining their props and behavior.

For more details, read our Composition guide.
unstyled
boolean

Whether to remove the component's style.

Previous

Segmented Control

Next

Select