In React, a controlled input is an input element whose value is controlled by React through the use of state. Therefore, an input should have a value that is not undefined or null to be a valid, controlled input.
This warning can happen if the state variable that holds the initial input value is undefined or null. Therefore, the input element will be uncontrolled when the component renders for the first time. However, when the state is updated to a non-null or non-undefined value, the input element becomes controlled, which triggers the warning.
Here is an example:
import { useEffect, useState } from "react"
export const TextInput = (props) => {
{/*This state variable is undefined when renders for the first time*/}
const [value, setValue] = useState();
const handleChange = (event) => {
setValue(event.target.value)
}
return (
<div>
{/* This input starts as uncontrolled because the value is undefined */}
<input type="text" value={value} onChange={handleChange} />
{/* Later on, the state value is updated to a non-null value */}
{value && <p>Value is {value}</p>}
</div>
)
}
As you can see, the state variable value is undefined when the component is rendered for the first time. That results in the input element rendering like the one below.
Now that is an uncontrolled input.
But soon after you type something into the input, the state value is updated, and the input value becomes defined. That makes the input a controlled input.
To fix this warning, you should ensure the input element is always controlled or uncontrolled and not switch between the two during the component's lifecycle.