30 Days Of React: Uncontrolled Component

Twitter Follow Author: Asabeneh Yetayeh
October, 2020
[<< Day 12](../12_Day_Forms/12_forms.md) | [Day 14 >>]() ![30 Days of React banner](../images/30_days_of_react_banner_day_13.jpg) - [Uncotrolled Components](#uncotrolled-components) - [Getting data from an uncontrolled input](#getting-data-from-an-uncontrolled-input) - [Getting multiple input data from form](#getting-multiple-input-data-from-form) - [Exercises](#exercises) - [Exercises: Level 1](#exercises-level-1) # Uncotrolled Components In the previous day challenge we have covered controlled inputs. In react most of the time we use controlled inputs as recommended on the official [documentation of React](https://reactjs.org/docs/uncontrolled-components.html). To write an uncontrolled component, instead of writing an event handler for every state update, you can use a ref to get form values from the DOM. In uncontrolled input we get data from input fields like traditional HTML form data handling. An example of uncontrolled component ## Getting data from an uncontrolled input ```js import React, { Component } from 'react' import ReactDOM from 'react-dom' class App extends Component { firstName = React.createRef() handleSubmit = (e) => { e.preventDefault() console.log(this.firstName.current.value) } render() { return (
) } } const rootElement = document.getElementById('root') ReactDOM.render(, rootElement) ``` ## Getting multiple input data from form We can grab multiple input data from DOM. We are not directly targeting the DOM but React is getting data from DOM using ref. ```js import React, { Component } from 'react' import ReactDOM from 'react-dom' class App extends Component { firstName = React.createRef() lastName = React.createRef() country = React.createRef() title = React.createRef() handleSubmit = (e) => { // stops the default behavior of form element specifically refreshing of page e.preventDefault() console.log(this.firstName.current.value) console.log(this.lastName.current.value) console.log(this.title.current.value) console.log(this.country.current.value) const data = { firstName: this.firstName.current.value, lastName: this.lastName.current.value, title: this.title.current.value, country: this.country.current.value, } // the is the place we connect backend api to send the data to the database console.log(data) } render() { return (

Add Student

) } } const rootElement = document.getElementById('root') ReactDOM.render(, rootElement) ``` Most of the time we use controlled input instead of uncontrolled input. In case if you want to target some element on the DOM you will use ref to get the content of that element. Don't touch directly using pure JavaScript. When you develop a React application do not touch the DOM directly because React has its own way of handling the DOM manipulation. # Exercises ## Exercises: Level 1 1. What is a controlled input? 2. What is an uncontrolled input 3. How do you get a content of a certain HTML element in React ? 4. Why it is not a good idea to touch the DOM directly in React ? 5. What is most frequently used in React ? Controlled or Uncontrolled input. 6. What do you need to write uncontrolled input? 7. Does state require to write uncontrolled input? 8. When do you use uncontrolled input? 9. When do you use controlled input? 10. Do you use a controlled or uncontrolled input to validate form input fields? 🎉 CONGRATULATIONS ! 🎉 [<< Day 12](../12_Day_Forms/12_forms.md) | [Day 14 >>]()