Functional vs Class-Components in React. Why Fuctional Components are better.

Created by eneaslari 30/10/2023

javascript

In the dynamic realm of web development, React.js 🌐 stands out as a robust and widely-used library for crafting user interfaces. With React, developers can create components using both functions and classes. However, functions have recently become more popular. This article delves into the reasons why functions are viewed as more effective than classes in React.js development, providing examples and insights to underscore this trend. 🚀

Understanding the Fundamentals

Differences Between Functional and Class Components

  1. Syntax The most apparent difference is in the syntax. A functional component is a plain JavaScript function that accepts props and returns a React element. In contrast, a class component requires extending from React.Component and creating a render function. 📝

  2. State With the React 16.8 Hooks update, you can now use the useState hook to manage state in your functional components. Previously, functional components, also known as stateless components, couldn't use setState(). If state management was necessary, you had to either create a class component or lift the state up to the parent component and pass it down via props. 🔀

  3. Lifecycle Hooks The React 16.8 Hooks update also introduced the useEffect hook, allowing you to use lifecycle events in functional components. Before this, lifecycle hooks were exclusive to class components due to their reliance on React.Component. ⏳

Benefits of Using Functions

With a basic understanding of both functions and classes in React.js, let's investigate why functions are becoming the go-to choice for numerous developers. 🤔

  1. Simplicity and Clarity A key reason for the preference towards function components is their simplicity. These components are more straightforward and readable compared to class components. Consider the following example:

Class Component:

class MyComponent extends React.Component {
  render() {
    return <div>Hello, World!</div>;
  }
}

Function Component:

function MyComponent() {
  return <div>Hello, World!</div>;
}

Clearly, the function component is more concise and less prone to errors. 🎈

  1. Enhanced Performance Function components generally perform better than class components. This advantage stems from the advent of React Hooks, enabling efficient state and side effect management in function components. Hooks like useState and useEffect have simplified these aspects. 💨

  2. Reusability Function components are conducive to reusability. They can be easily broken down into smaller, reusable components, leading to a more modular and maintainable codebase. This is crucial for developing scalable applications. 🔄

  3. Hooks and State Management Introduced in React 16.8, React Hooks have transformed how developers manage state in function components. With hooks, component state and lifecycle events can be handled without resorting to class-based components, thereby reducing excess code and enhancing code clarity. ✨

Advantages of Functional Components

  • They are easier to read and test, being plain JavaScript functions without state or lifecycle hooks. 📖
  • You end up writing less code. ✂️
  • They encourage best practices by separating container and presentational components. 🛠️
  • The React team has suggested potential performance improvements for functional components in future updates. 🚀

Examples and Applications

Example: Crafting a Counter Component To illustrate the difference between class and function components, let's create a simple counter component:

Class Component:

class Counter extends React.Component {
  constructor(props) {
    super(props);
    this.state = { count: 0 };
  }

  increment = () => {
    this.setState({ count: this.state.count + 1 });
  }

  render() {
    return (
      <div>
        <p>Count: {this.state.count}</p>
        <button onClick={this.increment}>Increment</button>
      </div>
    );
  }
}

Function Component using Hooks:

import React, { useState } from 'react';

function Counter() {
  const [count, setCount] = useState(0);

  const increment = () => {
    setCount(count + 1);
  };

  return (
    <div>
      <p>Count: {count}</p>
      <button onClick={increment}>Increment</button>
    </div>
  );
}

In this case, the function component using hooks is notably more streamlined and easier to grasp. 🌟

Conclusion

In the sphere of React.js development, function components have gained favor for their straightforwardness, superior performance, reusability, and the efficacy of React Hooks in managing state. While class components still maintain relevance, particularly in older codebases, function components are the preferred option for new projects and contemporary development practices. 🌱

Integrating function components into your React.js endeavors will not only refine your code but also enhance its maintainability and flexibility for future modifications. 💪

More to read