javascriptreactjsreact-hooks

Calling a hook inside a useMemo workaround


Currently I am mapping through a list in my react component:

const items = useMemo(() => {
  return items.map(item => {
    const element = useSearchResult(item)
  })
  ...
}, [dependencies])

I am aware that calling a hook inside a useMemo is bad practice and should not be done. However, how can I solve this issue?

I thought of doing this:

const element = (item) => useSearchResult(item)

const items = useMemo(() => {
  return items.map(item => {
    element(item)
  })
  ...
}, [dependencies])

I don't think this solves the issue of not calling a hook inside a useMemo.

useSearchResult will return a JSX element which is based on the item prop it receives.

const useSearchResult = ({ item }) => {
  return (
    <div>
      {item.name}
      {item.id}
    </div>
  )
}

Solution

  • const useSearchResult = ({item}) => {
     return (
       <div>
         {item.name}
         {item.id}
        </div>
     )
    }
    

    Since this code does not call any hooks (eg, useState, useEffect), it is not a custom hook. It does not need to follow the rules of hooks, meaning you can safely call it as many times as you like, and you can change the number of times on each render. The only thing you should do is change the name of it so no one (neither humans, nor automated tools like eslint) mistakenly thinks it needs to follow the rules of hooks.