
Security News
The Changelog Podcast: Practical Steps to Stay Safe on npm
Learn the essential steps every developer should take to stay secure on npm and reduce exposure to supply chain attacks.
@shortcm/checkbox
Advanced tools
Checkboxes allow the user to select one or more items from a set.
npm install @material/checkbox
We recommend using MDC Checkbox with MDC Form Field for enhancements such as label alignment, label activation of the ripple interaction effect, and RTL-awareness.
<div class="mdc-form-field">
  <div class="mdc-checkbox">
    <input type="checkbox"
           class="mdc-checkbox__native-control"
           id="checkbox-1"/>
    <div class="mdc-checkbox__background">
      <svg class="mdc-checkbox__checkmark"
           viewBox="0 0 24 24">
        <path class="mdc-checkbox__checkmark-path"
              fill="none"
              d="M1.73,12.91 8.1,19.28 22.79,4.59"/>
      </svg>
      <div class="mdc-checkbox__mixedmark"></div>
    </div>
  </div>
  <label for="checkbox-1">Checkbox 1</label>
</div>
Note: If you are using IE, you need to include a closing
</path>tag if you wish to avoid console warnings.
@import "@material/form-field/mdc-form-field";
@import "@material/checkbox/mdc-checkbox";
The checkbox will work without JavaScript, but you can enhance it with a ripple interaction effect by instantiating MDCCheckbox on the mdc-checkbox element. To activate the ripple effect upon interacting with the label, you must also instantiate MDCFormField on the mdc-form-field element and set the MDCCheckbox instance as its input.
import {MDCFormField} from '@material/form-field';
import {MDCCheckbox} from '@material/checkbox';
const checkbox = new MDCCheckbox(document.querySelector('.mdc-checkbox'));
const formField = new MDCFormField(document.querySelector('.mdc-form-field'));
formField.input = checkbox;
See Importing the JS component for more information on how to import JavaScript.
Note that mdc-checkbox--disabled is necessary on the root element of CSS-only checkboxes to prevent hover states from activating. Checkboxes that use the JavaScript component do not need this class; a disabled attribute on the <input> element is sufficient.
<div class="mdc-checkbox mdc-checkbox--disabled">
  <input type="checkbox"
         id="basic-disabled-checkbox"
         class="mdc-checkbox__native-control"
         disabled />
  <div class="mdc-checkbox__background">
    <svg class="mdc-checkbox__checkmark"
         viewBox="0 0 24 24">
      <path class="mdc-checkbox__checkmark-path"
            fill="none"
            d="M1.73,12.91 8.1,19.28 22.79,4.59"/>
    </svg>
    <div class="mdc-checkbox__mixedmark"></div>
  </div>
</div>
<label for="basic-disabled-checkbox" id="basic-disabled-checkbox-label">This is my disabled checkbox</label>
MDC Checkbox uses MDC Theme's secondary color by default for "marked" states (i.e., checked or indeterminate).
The following mixins apply only to enabled checkboxes. It is not currently possible to customize the color of a disabled checkbox.
| Mixin | Description | 
|---|---|
| mdc-checkbox-container-colors($unmarked-stroke-color, $unmarked-fill-color, $marked-stroke-color, $marked-fill-color, $generate-keyframes) | Generates CSS classes to set and animate the stroke color and/or container fill color of a checkbox | 
| mdc-checkbox-ink-color($color) | Sets the ink color of the checked and indeterminate icons | 
| mdc-checkbox-focus-indicator-color($color) | Sets the color of the focus indicator | 
The ripple effect for the Checkbox component is styled using MDC Ripple mixins.
mdc-checkbox-container-colors($unmarked-stroke-color, $unmarked-fill-color, $marked-stroke-color, $marked-fill-color, $generate-keyframes)Stroke and fill color may be customized independently in both the marked and unmarked state.
All parameters are optional, and if left unspecified will use their default values.
If you plan to use CSS-only checkboxes, set $generate-keyframes to false to prevent the mixin from generating @keyframes and CSS classes used by the JavaScript component.
In browsers that fully support CSS variables, MDC Checkbox references CSS variables wherever theme properties are used.
However, due to Edge's buggy CSS variable support, the background-color for .mdc-checkbox__background::before will not honor CSS variables in Edge.
This means you will need to override this style manually for Edge if you alter the CSS variable for the primary color.
MDCCheckbox Properties and Methods| Property Name | Type | Description | 
|---|---|---|
| checked | Boolean | Setter/getter for the checkbox's checked state | 
| indeterminate | Boolean | Setter/getter for the checkbox's indeterminate state | 
| disabled | Boolean | Setter/getter for the checkbox's disabled state | 
| value | String | Setter/getter for the checkbox's | 
If you are using a JavaScript framework, such as React or Angular, you can create a Checkbox for your framework. Depending on your needs, you can use the Simple Approach: Wrapping MDC Web Vanilla Components, or the Advanced Approach: Using Foundations and Adapters. Please follow the instructions here.
MDCCheckboxAdapter| Method Signature | Description | 
|---|---|
| addClass(className: string) => void | Adds a class to the root element. | 
| removeClass(className: string) => void | Removes a class from the root element. | 
| getNativeControl() => HTMLInputElement? | Returns the native checkbox control, if available. Note that if this control is not available, the methods that rely on it will exit gracefully. | 
| forceLayout() => void | Force-trigger a layout on the root element. This is needed to restart animations correctly. If you find that you do not need to do this, you can simply make it a no-op. | 
| isAttachedToDOM() => boolean | Returns true if the component is currently attached to the DOM, false otherwise. | 
| isIndeterminate() => boolean | Returns true if the component is in the indeterminate state. | 
| isChecked() => boolean | Returns true if the component is checked. | 
| hasNativeControl() => boolean | Returns true if the input is present in the component. | 
| setNativeControlDisabled(disabled: boolean) => void | Sets the input to disabled. | 
MDCCheckboxFoundation| Method Signature | Description | 
|---|---|
| setDisabled(disabled: boolean) => void | Updates the disabledproperty on the underlying input. Does nothing when the underlying input is not present. | 
| handleAnimationEnd() => void | animationendevent handler that should be applied to the root element. | 
| handleChange() => void | changeevent handler that should be applied to the checkbox element. | 
FAQs
The Material Components for the web checkbox component
The npm package @shortcm/checkbox receives a total of 0 weekly downloads. As such, @shortcm/checkbox popularity was classified as not popular.
We found that @shortcm/checkbox demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Learn the essential steps every developer should take to stay secure on npm and reduce exposure to supply chain attacks.

Security News
Experts push back on new claims about AI-driven ransomware, warning that hype and sponsored research are distorting how the threat is understood.

Security News
Ruby's creator Matz assumes control of RubyGems and Bundler repositories while former maintainers agree to step back and transfer all rights to end the dispute.