NV Elements Catalog Starters Repo System Themes Getting Started Getting Started Installation CLI MCP Skills Lint Integrations Getting Started Angular Bundles Custom Elements Golang Hugo Import Maps Lit Lit Library MCP Apps NextJS Nuxt Preact React SolidJS Svelte TypeScript Vue About Changelog Metrics Support Accessibility Contributions Requests Migration Foundations Overview 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 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 Chat 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 Agent Tooling Agent Ownership Documentation Examples TypeScript Testing Unit Testing Accessibility Testing Lighthouse Testing SSR Testing Visual Testing Troubleshooting Component Creation Internal Examples All Examples

Icon Button

stable:  0.2.4 Coverage: 100.00% Bundle: 18.22kb Lighthouse: 100 Axe Core Released: 0.2.1
Overview API Examples
DefaultInteractionsSizeFlatInteractionsPressedPressedFlatPressedInlineSelectedSelectedFlatSelectedInlineCustomIconLinkThemes

Default

An icon button is a button that displays only an icon without a visual label.

Interactions

Icon buttons with different interaction styles including default, emphasis, destructive, and disabled states.

Size

test-case

Controls the visual scale of an element to match its importance and available space.

Size Description sm Compact size for dense layouts or secondary elements with less visual prominence. md Standard size that works well in most contexts and provides balanced visibility. lg Larger size for emphasizing important elements or improving touch targets in spacious layouts.

Flat Interactions

test-case

Flat container icon buttons with interaction styles for minimal visual weight in dense toolbars.

Pressed

Indicates the current state of a toggle button that switches on or off. MDN

Pressed Description true The button is in the pressed (on) state and the associated action or setting is active. false The button is in the unpressed (off) state and the associated action or setting is inactive.

Pressed Flat

test-case

Flat icon buttons with pressed state for low-emphasis toggles and compact toggle controls.

Pressed Inline

test-case

Inline icon buttons with pressed state for minimal toggle controls within text or content flows.

Selected

Indicates whether an element currently holds selection within a multi-option selection group. MDN

Selected Description true The element holds selection and represents the user's current choice within the group. false The element does not hold selection and the user can choose it.

Selected Flat

test-case

Flat icon buttons with selected state for low-emphasis mode selection in compact toolbars.

Selected Inline

test-case

Inline icon buttons with selected state for minimal mode selection within content flows.

Custom Icon

test-case
ML 🎉 🔗
Edit Example

Icon buttons with custom content like text initials, emojis, or symbols for personalized actions.

Proper implementation of icon buttons with links, showing correct and incorrect anchor placement patterns.

Themes

test-case

Icon buttons styled for light and dark themes with all interaction states for theme consistency.