Skip to content

Instantly share code, notes, and snippets.

@james0r
Created November 14, 2023 04:03
Show Gist options
  • Save james0r/f7fd5e2d3bea5b055a6c6ce4a58a4345 to your computer and use it in GitHub Desktop.
Save james0r/f7fd5e2d3bea5b055a6c6ce4a58a4345 to your computer and use it in GitHub Desktop.

React Hooks are a feature introduced in React version 16.8 that allow you to use state and other React features without writing a class. They are JavaScript functions that let you "hook into" React state and lifecycle features from function components Source 3.

There are two main rules for using hooks in React:

  1. Only call hooks at the top level: Don't call hooks inside loops, conditions, or nested functions. Instead, always use hooks at the top level of your React function, before any return keyword Source 2.

  2. Only call hooks from React function components or custom hooks: You should never call hooks from regular JavaScript functions. However, you can call hooks from React functional components and custom hooks Source 2.

These rules are enforced by the ESLint plugin called eslint-plugin-react-hooks. You can add this plugin to your project to enforce these rules Source 0.

// Your ESLint configuration
{
 "plugins": [
   // ...
   "react-hooks"
 ],
 "rules": {
   // ...
   "react-hooks/rules-of-hooks": "error", // Checks rules of Hooks
   "react-hooks/exhaustive-deps": "warn" // Checks effect dependencies
 }
}

React also provides a few built-in hooks like useState, useEffect, and others. You can also create your own custom hooks to reuse stateful behavior between different components Source 3.

For example, a custom hook could look like this:

//useFetch.js
import { useState, useEffect } from "react";
export function useFetch(url) {
   const [data, setData] = useState(null);
   const [error, setError] = useState("");
   useEffect(() => {
       fetch(url)
       .then(res => {
           if (!res.ok) {
           throw Error("something wrong, çould not connect to resource");
       }
       setData(res.json());
       })
       .then(() => {
       	setError("");
       })
       .catch( error => {
           console.warn(`sorry an error occurred, due to ${error.message} `);
           setData(null);
           setError(error.message);
       });
   }, [url]);
   return [data, error];
}

This custom hook useFetch can be used anywhere in your app simply by importing the function and passing an API path as an argument Source 2.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment