Button

<wa-button> Stable Since 2.0

Buttons represent actions the user can take, such as submitting a form, opening a dialog, or navigating to another page.

Button

Examples

Link to This Section

Variants

Link to This Section

Use the variant attribute to set the button's semantic variant.

Appearance

Link to This Section

Use the appearance attribute to change the button's visual appearance.

Sizes

Link to This Section

Use the size attribute to change a button's size.

Pill Buttons

Link to This Section

Use the pill attribute to give buttons rounded edges.

Link to This Section

It's often helpful to have a button that works like a link. This is possible by setting the href attribute, which will make the component render an <a> under the hood. This gives you all the default link behavior the browser provides (e.g. CMD/CTRL/SHIFT + CLICK) and exposes the rel, target, and download attributes.

Icon Buttons

Link to This Section

When only an icon is slotted into the label slot, the button becomes an icon button. In this case, it's important to give the icon a label for users with assistive devices. Icon buttons can use any appearance or variant.

Setting a Custom Width

Link to This Section

As expected, buttons can be given a custom width by setting the width CSS property. This is useful for making buttons span the full width of their container on smaller screens.

Start & End Decorations

Link to This Section

Use the start and end slots to add presentational elements like <wa-icon> next to the button label.

Caret

Link to This Section

Use the with-caret attribute to add a dropdown indicator when a button will trigger a dropdown, menu, or popover.

Loading

Link to This Section

Use the loading attribute to make a button busy. The width will remain the same as before, preventing adjacent elements from moving around.

Disabled

Link to This Section

Use the disabled attribute to disable a button.

Brand Success Neutral Warning Danger

Link New Window Download

Styling Buttons

Link to This Section

This example demonstrates how to style buttons using a custom class. This is the recommended approach if you need to add additional variations. To customize an existing variation, modify the selector to target the button's variant attribute instead of a class (e.g. wa-button[variant="brand"]).

Pink Button

Importing

Link to This Section

If you're using the autoloader or a hosted project, components load on demand — no manual import needed. To cherry-pick a component manually, use one of the following snippets.

CDN npm Self-Hosted React

Import this component directly from the CDN:

import 'https://ka-f.webawesome.com/[email protected]/components/button/button.js';

After installing Web Awesome via npm, import this component:

import '@awesome.me/webawesome/dist/components/button/button.js';

If you're self-hosting Web Awesome, import this component from your server:

import './webawesome/dist/components/button/button.js';

To import this component for React 18 or below, use the following code:

import WaButton from '@awesome.me/webawesome/dist/react/button/index.js';

Slots

Link to This Section

Learn more about using slots.

Attributes & Properties

Link to This Section

Learn more about attributes and properties.

Methods

Link to This Section

Learn more about methods.

Events

Link to This Section

Learn more about events.

Custom States

Link to This Section

Learn more about custom states.

CSS parts

Link to This Section

Learn more about CSS parts.

Dependencies

Link to This Section

This component automatically imports the following elements. Sub-dependencies, if any exist, will also be included in this list.

Need a hand? Report a bug Ask for help
    No results