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

Forms

The form control elements leverage the native browser inputs as its public API. This approach allows any framework or library to use the form elements and keeps the API simple without obfuscating the native browser APIs.

Installation

The form elements use individual sub imports/entrypoints.


    

    

Framework Integrations

Each frontend framework typically provides its own guidance and best practices for creating forms.

See the links below for specific integration patterns for the following frameworks:

Lit Integration Angular Integration

Form layouts

All form elements support the following layouts for label placement, horizontal, horizontal-inline, vertical and vertical-inline. Vertical is the default label layout for all elements.

Horizontal Inline

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.

Space-efficient horizontal layout with inline labels, ideal for dense forms with tight vertical space where quick scanning matters.

message message message message message message message message message message

Horizontal

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.

Horizontal form layout with labels beside inputs, creating efficient use of horizontal space and familiar desktop form patterns.

message message message message message message message message message message

Vertical

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.

Traditional vertical form layout with labels above inputs, providing clear visual hierarchy and optimal readability for complex forms.

message message message message message message message message message message

Vertical Inline

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.

Compact vertical layout with inline labels and controls, maximizing space efficiency while maintaining form clarity and accessibility.

message message message message message message message message 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

Form controls that automatically adjust their width to fit content, optimizing space usage for dynamic or variable-length inputs.

message message message

Kitchen Sink

Comprehensive showcase of all form controls in a grid layout, including input types, states, and advanced patterns use for a complete form design reference.

message message message message message message message message message message https:// .com message message message .com Host ID: 123456 message message message message message message message message message message