Switch

Switches toggle the state of an item on or off.

Two switches on a settings page for Wi-Fi and Bluetooth. The first is on and the second is off.

View interactive demo inline.

Open interactive demo in new tab.

Switches are similar to checkboxes, and can be unselected or selected.

<md-switch></md-switch>
<md-switch selected></md-switch>

Icons can be used to visually emphasize the switch's selected state. Switches can choose to display both icons or only selected icons.

<md-switch icons></md-switch>
<md-switch icons selected></md-switch>

<md-switch icons show-only-selected-icon></md-switch>
<md-switch icons show-only-selected-icon selected></md-switch>

Associate a label with a switch using the <label> element.

<label>
  Wi-Fi
  <md-switch selected></md-switch>
</label>

<label for="switch">Bluetooth</label>
<md-switch id="switch"></md-switch>

Add an aria-label attribute to switches without labels or switches whose labels need to be more descriptive.

<md-switch aria-label="Lights"></md-switch>

<label>
  All
  <md-switch aria-label="All notifications"></md-switch>
</label>
bookmark

switches are not automatically labelled by <label> elements and always need an aria-label. See b/294081528.

Switches supports Material theming and can be customized in terms of color and shape.

TokenDefault value
--md-switch-handle-color--md-sys-color-outline
--md-switch-handle-shape--md-sys-shape-corner-full
--md-switch-track-color--md-sys-color-surface-container-highest
--md-switch-track-shape--md-sys-shape-corner-full
--md-switch-selected-handle-color--md-sys-color-on-primary
--md-switch-selected-track-color--md-sys-color-primary
<style>
  :root {
    /* System tokens */
    --md-sys-color-primary: #006a6a;
    --md-sys-color-on-primary: #ffffff;
    --md-sys-color-outline: #6f7979;
    --md-sys-color-surface-container-highest: #dde4e3;

    /* Component tokens */
    --md-switch-handle-shape: 0px;
    --md-switch-track-shape: 0px;
  }
</style>

<md-switch></md-switch>
<md-switch selected></md-switch>
PropertyAttributeTypeDefaultDescription
selectedselectedbooleanfalsePuts the switch in the selected state and sets the form submission value to the value property.
iconsiconsbooleanfalseShows both the selected and deselected icons.
showOnlySelectedIconshow-only-selected-iconbooleanfalseShows only the selected icon, and not the deselected icon. If true, overrides the behavior of the icons property.
requiredrequiredbooleanfalseWhen true, require the switch to be selected when participating in form submission.
https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#validation
valuevaluestring'on'The value associated with this switch on form submission. null is submitted when selected is false.
disabledbooleanundefined
namestringundefined
MethodParametersReturnsDescription
formResetCallbackNonevoid
formStateRestoreCallbackstatevoid
EventTypeBubblesComposedDescription
inputInputEventNoNoFired whenever selected changes due to user interaction (bubbles and composed).
changeEventNoNoFired whenever selected changes due to user interaction (bubbles).
About
IntroductionQuick StartRoadmapSupportBundle Sizes
Theming
Material ThemingColorTypographyShape
Components
ButtonsCheckboxChipsDialogsFloating action button (FAB)Icon ButtonsListsMenusProgress indicatorsRadioRippleSelectSlidersSwitchTabsText field