Monday, 25 October 2021

What is React Components?

 Earlier, the developers write more than thousands of lines of code for developing a single page application. These applications follow the traditional DOM structure, and making changes in them was a very challenging task. If any mistake found, it manually searches the entire application and update accordingly. 

The component-based approach was introduced to overcome an issue. In this approach, the entire application is divided into a small logical group of code, which is known as components.

A Component is considered as the core building blocks of a React application. It makes the task of building UIs much easier. Each component exists in the same space, but they work independently from one another and merge all in a parent component, which will be the final UI of your application.

Every React component have their own structure, methods as well as APIs. They can be reusable as per your need. For better understanding, consider the entire UI as a tree. Here, the root is the starting component, and each of the other pieces becomes branches, which are further divided into sub-branches.

React Components

In ReactJS, we have mainly two types of components. They are

  1. Functional Components
  2. Class Components

Functional Components

In React, function components are a way to write components that only contain a render method and don't have their own state. They are simply JavaScript functions that may or may not receive data as parameters. We can create a function that takes props(properties) as input and returns what should be rendered. A valid functional component can be shown in the below example.

  1. function WelcomeMessage(props) {  
  2.   return <h1>Welcome to the , {props.name}</h1>;  
  3. }  

The functional component is also known as a stateless component because they do not hold or manage state. It can be explained in the below example.

Example

  1. import React, { Component } from 'react';  
  2. class App extends React.Component {  
  3.    render() {  
  4.       return (  
  5.          <div>  
  6.             <First/>  
  7.             <Second/>  
  8.          </div>  
  9.       );  
  10.    }  
  11. }  
  12. class First extends React.Component {  
  13.    render() {  
  14.       return (  
  15.          <div>  
  16.             <h1>JavaTpoint</h1>  
  17.          </div>  
  18.       );  
  19.    }  
  20. }  
  21. class Second extends React.Component {  
  22.    render() {  
  23.       return (  
  24.          <div>  
  25.             <h2>www.javatpoint.com</h2>  
  26.             <p>This websites contains the great CS tutorial.</p>  
  27.          </div>  
  28.       );  
  29.    }  
  30. }  
  31. export default App;  

Output:

React Components

Class Components

Class components are more complex than functional components. It requires you to extend from React. Component and create a render function which returns a React element. You can pass data from one class to other class components. You can create a class by defining a class that extends Component and has a render function. Valid class component is shown in the below example.

  1. class MyComponent extends React.Component {  
  2.   render() {  
  3.     return (  
  4.       <div>This is main component.</div>  
  5.     );  
  6.   }  
  7. }  

The class component is also known as a stateful component because they can hold or manage local state. It can be explained in the below example.

Example

In this example, we are creating the list of unordered elements, where we will dynamically insert StudentName for every object from the data array. Here, we are using ES6 arrow syntax (=>) which looks much cleaner than the old JavaScript syntax. It helps us to create our elements with fewer lines of code. It is especially useful when we need to create a list with a lot of items.

  1. import React, { Component } from 'react';  
  2. class App extends React.Component {  
  3.  constructor() {  
  4.       super();  
  5.       this.state = {  
  6.          data:   
  7.          [  
  8.             {             
  9.                "name":"Abhishek"             
  10.             },  
  11.             {            
  12.                "name":"Saharsh"             
  13.             },  
  14.             {    
  15.                "name":"Ajay"          
  16.             }  
  17.          ]  
  18.       }  
  19.    }  
  20.    render() {  
  21.       return (  
  22.          <div>  
  23.             <StudentName/>  
  24.             <ul>            
  25.                 {this.state.data.map((item) => <List data = {item} />)}           
  26.             </ul>  
  27.          </div>  
  28.       );  
  29.    }  
  30. }  
  31. class StudentName extends React.Component {  
  32.    render() {  
  33.       return (  
  34.          <div>  
  35.             <h1>Student Name Detail</h1>  
  36.          </div>  
  37.       );  
  38.    }  
  39. }  
  40. class List extends React.Component {  
  41.    render() {  
  42.       return (  
  43.          <ul>            
  44.             <li>{this.props.data.name}</li>   
  45.          </ul>  
  46.       );  
  47.    }  
  48. }  
  49. export default App;  

Output:

React Components


No comments:

Post a Comment