NV Elements Catalog Starters Repo System Themes About Getting Started Changelog Metrics Support Accessibility Contributions Requests Migration Integrations Installation MCP CLI Lint Angular Bundles Extensions Golang Hugo Import Maps Lit NextJS Nuxt Preact React SolidJS Svelte TypeScript Vue Foundations Typography Iconography Themes Design Tokens Size & Space Objects Interactions Support Status Color Animation Fonts Layers Custom Layout Horizontal Vertical Grid Popovers i18n Visualization View Transitions Elements Accordion Alert Avatar Badge Breadcrumb Button Button Group Card Chat Message Checkbox Color Combobox Copy Button Datagrid Integrations Column Action Column Alignment Column Fixed Column width Container Card Display Settings Footer Heatmap Keynav Multi Select Pagination Panel Detail Panel Grid Performance Placeholder Row Action Row Groups Row Sort Scroll Height Single Select Stripe Date Datetime Dialog Divider Dot Drawer Dropdown Dropdown Group Dropzone File Format Datetime Format Number Format Relative Time Forms Validation Actions Control Icon Icon Button Input Input Group Logo Menu Month Notification Page Page Header Page Loader Pagination Panel Progressive Filter Chip Progress Bar Progress Ring Password Preferences Input Pulse Radio Range Resize Handle Search Select Skeleton Sort Button Sparkline Star Rating Steps Switch Tabs Tag Textarea Time Toast Toggletip Toolbar Tooltip Tree Week Patterns Authentication Browse Dashboard Editor Empty States Heatmap Keyboard Shortcut Logging Media Navigation Onboarding Panel Responsive Search Subheader Trend Code Codeblock Monaco Input Diff Input Editor Diff Editor Problems Markdown Markdown CSS Utility Labs Responsive Layout Viewport Container Patterns Forms API Design Properties & Attributes Slots Registration CustomEvents Stateless Composition Styles Packaging Glossary Logs Internal Guidelines Agent Harness Documentation Examples TypeScript Testing Unit Testing Accessibility Testing Lighthouse Testing SSR Testing Visual Testing Troubleshooting Component Creation Internal Examples All Examples

Select

stable:  0.1.1 Coverage: 95.45% Bundle: 33.92kb Lighthouse: 100 Axe Core Released: 0.3.0
Overview API Examples

A select is a control that enables users to select an option from a list of options.

message

Installation


    

    
CLI / MCP

Many

The many option behavior preserves the native select value behavior. The value on the select only reflects the first selected value. To get all selected options check the selected property on each <option> element or the select property selectedOptions.

Many-selection mode allowing users to select many options simultaneously.

message

If the many tags overflow the parent container a simple text label appears instead.

Multi-selection with constrained width to show overflow handling of selected options.

message

Flat

Flat container style for single and multi select, providing a minimal visual treatment.

message message message

Layout

Controls the directional arrangement and spacing behavior of the element's content.

Layout Description vertical Arranges content in a vertical stack with block-level spacing. vertical-inline Arranges content vertically with compact inline spacing for dense layouts. horizontal Arranges content in a horizontal row with block-level spacing. horizontal-inline Arranges content horizontally with compact inline spacing.

Vertical

Vertical layout showcasing states: default, disabled, success, and error.

message message message message

Horizontal

Horizontal layout showcasing states: default, disabled, success, and error.

message message message message

Placeholder

Placeholder text prompts users to make a selection when no option exists yet.

message

Placeholder text in multi-selection mode guides users before they select any options.

message

Disabled

Disable individual options to prevent selection while keeping them visible.

message

Height

Determines the scroll height of selection in open dropdown.

Custom scroll height for dropdown with many options to control vertical space usage.

message message

Size

Enables size attribute on the select element. This creates a inline selection at the defined item height.

Size attribute controls the number of visible options without scrolling.

message message

Prefix

Select with a prefix button to provide extra context or categorization.

location

Fit Content

Sets the input to match native default content block

FitContent Description true false

Select width adjusts to fit the longest option in both vertical and horizontal layouts.

message message

Fit Text

Sets the input to match the width of the active text content of the control value. Only applicable to vertical input box type controls (input, select)

FitText Description true false

Select width dynamically adjusts to fit the currently selected option text.

message

Performance

Performance test for select element with 1000 options

Release Status

All elements and features go through 3 phases of stability, pre-release, beta and stable.

pre-release
Docs Preview API Documentation Fully Themeable
beta
Robust unit test coverages Passed API Review Passed Designer VQA Review Included in library package
stable
No known outstanding AA WCAG issues No known outstanding performance issues Adapts to different screen/container sizes No breaking API changes for at least 90 days