useState()
The useState()
hook returns the current state of the component and its setter function. State must be changed through the setter only and not be mutated directly as it may cause unexpected behavior.
Syntax
import React, { useState } from 'react';
const [state, setState] = useState(initialValue);
When the component is first rendered, its state
is assigned an initialValue
through the useState()
hook. If one is not provided, the default value is undefined
. Afterwards, the setState
function can change the value of state
and trigger a re-render of the component.
The state
must be changed only through the setState
function and not be mutated directly as this may cause unexpected behavior.
The return value of useState()
is an array whose elements (the state and setter function) can be accessed through destructuring.
Note: The name of the setter function should correlate with the name of the
state
value (e.g.,const [time, setTime] = useState(0);
).
Example 1
A controlled input whose value depends on the name
state and changes it through setName
setter on onChange
event.
import React, { useState } from 'react';function ProfileName() {const [name, setName] = useState('');function handleChange(event) {/*Sets the name state to the value ofthe input after the onChange event.*/setName(event.currentTarget.value);}return <input value={name} onChange={handleChange} />;}
Example 2
In cases where the component state is an array or object, the setter function must update with a modified copy of the state, not the original.
The following example involves deleting an item from the foods
state array and updating with filteredItems
through the onClick
event:
import React, { useState } from 'react';function FavoriteFoodList() {const [foods, setFoods] = useState(['pizza', 'hot dog']);function handleDeleteFood(deletedIndex) {/*Instead of changing the foods array directly,the .filter() method can be used to return acopy that excludes the deleted item.*/const filteredItems = foods.filter((food, index) => index !== deletedIndex);setFoods(filteredItems);}return (<div>{foods.map((item, index) => (<button onClick={() => handleDeleteFood(index)}>{item}</button>))}</div>);}
Looking to contribute?
- Learn more about how to get involved.
- Edit this page on GitHub to fix an error or make an improvement.
- Submit feedback to let us know how we can improve Docs.