1. Controlled components
In HTML, form elements such as ,
In React, mutable state is usually stored in the component’s state property and can only be updated by using setState(). We can combine the two to make the React state the “unique data source.” The React component that renders the form also controls what happens to the form during user input.
The form input elements that React controls their values in this way are called “controlled components.”
In short, a controlled component provides both values and methods of action, such as:
<FInput Value ={x} onChange={fn}/> Controlled componentsCopy the code
Ii. Uncontrolled components
Unlike controlled components, uncontrolled components are only given initial values, regardless of operations such as:
<FInput defaultValue={x} ref={input}/> Uncontrolled componentsCopy the code
Use the REF to get form data from the DOM node.
Because uncontrolled components store real data in DOM nodes, it can sometimes be easier to integrate React and non-React code when using uncontrolled components, which can affect code aesthetics, but using uncontrolled components can often reduce code volume.
React recommends using controlled components.
Three, the difference between the two
Form data for controlled components is managed by the React component. The form data of uncontrolled components is handed over to DOM nodes for processing.
That is, the state of a controlled component is maintained by the developer, and the state of an uncontrolled component is maintained by the component itself (out of the developer’s control).