NV Elements Catalog Starters Repo System Themes About Getting Started Changelog Metrics Support Accessibility Contributions Requests Migration Deprecations Integrations Installation MCP CLI Lint Angular Bundles Extensions Go 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 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 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

Form Validation

The control supports validation statuses such as error and success. These statuses can be toggle by any framework level forms API. But the control component does also support the native HTML Validation API. Defining a Validity State on a control-message allows messages to appear conditionally based on the current input validity state.

To manage validation manually use the novalidate attribute to disable HTML5 validation. If you are using a framework that manages validation like Angular, then novalidate is automatically applied. MDN Validity State

Use real-time validation with contextual error messages to disable submit until form is valid.

required invalid NVIDIA email required minimum length is 6 characters login to account

    

Reset

Individual controls can be reset by calling the reset() method on the control element. If controls are in a HTML Form then calling reset() on the form resets all child controls.

Form reset functionality allowing users to clear individual fields or reset the entire form.

required invalid NVIDIA email required reset form

Error Groups

Login form with grouped error display showing all validation issues together after submission attempt.

invalid email minimum length is 6 characters login to account invalid email password required

Success Groups

Login form example of success feedback with positive confirmation messages for valid input and successful form submission.

username available login to account account created