Creating Custom Checkboxes in React

In this tutorial, we’ll explore how to build custom checkboxes in React while maintaining accessibility for assistive technology. We’ll cover the basics of working with form controls in React and provide a step-by-step guide on creating a custom checkbox component.

Understanding Default and Custom Checkboxes in React

Checkboxes are control elements that allow users to toggle between true and false states. In HTML, checkboxes have default styles applied to them, which can vary across browsers. To ensure consistency in appearance, we may want to create custom checkboxes.

Using Controlled Inputs for Form Controls in React

In React, form controls, including checkboxes, must be either controlled or uncontrolled inputs. Controlled inputs allow us to manage the state of the input, whereas uncontrolled inputs rely on the DOM. React recommends using controlled inputs for form controls.

Creating a Checkbox Component

Let’s start by creating a Checkbox component that accepts a label text as a prop and renders a checkbox alongside the text.
“`jsx
import React from ‘react’;

const Checkbox = ({ label }) => {
return (


{label}

);
};

export default Checkbox;
“`
Controlling the Input Checkbox

To make the checkbox a controlled input, we need to add a component state to manage the user’s input. We’ll use the useState hook to initialize the state and update it when the user interacts with the checkbox.
“`jsx
import React, { useState } from ‘react’;

const Checkbox = ({ label }) => {
const [isChecked, setIsChecked] = useState(false);

const handleCheckboxChange = () => {
setIsChecked(!isChecked);
};

return (


{label}

);
};

export default Checkbox;
“`
Styling the Checkbox

To give our checkbox a custom look, we can use CSS to style the input element. We’ll use the appearance property to remove the default styles and add our own custom styles.
“`css
.checkbox {
appearance: none;
width: 20px;
height: 20px;
border: 1px solid #ccc;
border-radius: 50%;
background-color: #fff;
}

.checkbox:checked {
background-color: #007bff;
border-color: #007bff;
}

**Using the
:checked` Selector**

Instead of adding a custom class to the input element, we can use the :checked selector to target the checked state of the checkbox.
css
.checkbox:checked {
background-color: #007bff;
border-color: #007bff;
}

Handling Multiple Checkboxes

When handling multiple checkboxes, we can use an array to store the state of each checkbox. We’ll use the useState hook to initialize the array and update it when the user interacts with each checkbox.
“`jsx
import React, { useState } from ‘react’;

const CheckboxGroup = () => {
const [checkboxes, setCheckboxes] = useState([
{ id: 1, isChecked: false },
{ id: 2, isChecked: false },
{ id: 3, isChecked: false },
]);

const handleCheckboxChange = (id) => {
setCheckboxes(
checkboxes.map((checkbox) =>
checkbox.id === id ? { …checkbox, isChecked: !checkbox.isChecked } : checkbox
)
);
};

return (

{checkboxes.map((checkbox) => (


Checkbox {checkbox.id}

))}

);
};

export default CheckboxGroup;
“`
By following these steps, you can create custom checkboxes in React that are accessible and easy to use.

Leave a Reply