Avatar

Otabek

Developer

Writing Clean Code With React

thumbnail

Clean code is the cornerstone of maintainable and scalable applications. In this blog post, we'll explore some best practices for writing clean code in React, ensuring your codebase remains readable and efficient.

1. Organize Your Components

Structure Components by Feature or Function

Organize your components in a way that reflects their purpose. This helps in keeping your project well-structured and easier to navigate.

src/
├── components/
│   ├── Header/
│   │   ├── Header.js
│   │   └── Header.css
│   ├── Footer/
│   │   ├── Footer.js
│   │   └── Footer.css
│   └── Button/
│       ├── Button.js
│       └── Button.css
├── pages/
│   ├── Home.js
│   └── About.js
└── App.js

2. Use Functional Components and Hooks

Functional components are simpler and more concise than class components. Combine them with hooks for managing state and lifecycle methods.

import React, { useState, useEffect } from "react";

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

  useEffect(() => {
    document.title = `Count: ${count}`;
  }, [count]);

  return (
    <div>
      <p>Current Count: {count}</p>
      <button onClick={() => setCount(count + 1)}>Increase</button>
    </div>
  );
};

export default Counter;

3. Follow a Consistent Naming Convention

Use clear and descriptive names for your variables, functions, and components.

// Bad
const x = () => {
  /* ... */
};

// Good
const fetchUserData = () => {
  /* ... */
};

4. Break Down Components into Smaller Units

Avoid monolithic components. Break down complex components into smaller, reusable pieces.

const UserProfile = ({ user }) => (
  <div>
    <Avatar src={user.avatar} />
    <UserDetails name={user.name} email={user.email} />
  </div>
);

const Avatar = ({ src }) => <img src={src} alt="User Avatar" />;
const UserDetails = ({ name, email }) => (
  <div>
    <h2>{name}</h2>
    <p>{email}</p>
  </div>
);

5. Use PropTypes for Type Checking

Leverage PropTypes to ensure components receive the right props.

import PropTypes from "prop-types";

const Button = ({ label, onClick }) => (
  <button onClick={onClick}>{label}</button>
);

Button.propTypes = {
  label: PropTypes.string.isRequired,
  onClick: PropTypes.func.isRequired,
};

6. Avoid Hardcoding Styles

Use CSS modules, styled-components, or utility classes like Tailwind CSS to keep styles modular and maintainable.

import styles from "./Button.module.css";

const Button = ({ label }) => (
  <button className={styles.button}>{label}</button>
);

export default Button;

Example CSS Module (Button.module.css)

.button {
  background-color: #007bff;
  color: white;
  padding: 10px 20px;
  border: none;
  border-radius: 5px;
}

7. Handle Side Effects with Care

Always clean up side effects in useEffect to avoid memory leaks.

useEffect(() => {
  const timer = setInterval(() => {
    console.log("Interval running");
  }, 1000);

  return () => clearInterval(timer);
}, []);

Conclusion

Writing clean code in React is about readability, maintainability, and scalability. By following these best practices, you ensure your codebase remains robust and easier to work with, even as your application grows. Happy coding!

For Example

Code Snippet

Copyright ⓒ —2025