0

I want to call a useFetch function in my project. I have to get 3 parameters for running this API. I created a function for that but there is an error:

Error: Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:

  1. You might have mismatching versions of React and the renderer (such as React DOM)
  2. You might be breaking the Rules of Hooks
  3. You might have more than one copy of React in the same app
 26 | export default function ProductTypeList() { 27 | async function ConfirmFunction(credit, userID, operation) { > 28 | return useFetch( 29 | "/credit/add?userId=" + 

How can I fix it?

export default function ProductTypeList() { async function ConfirmFunction(credit, userID, operation) { return useFetch( "/credit/add?userId=" + userID + "&amount=" + credit + "&type=" + operation ); } ... return <Button color="primary" onClick={() => ConfirmFunction(selectedAmount, select, selectOperation) } > Okay </Button> 

Note: All parameters are true.

2
  • 1
    The error speaks itself, Hooks can only be called inside of the body of a function component. so move your ConfirmFunction inside ProductTypeList. Commented Jan 31, 2022 at 12:52
  • Don't name a function starting with use unless it's going to be at the Top Level. All functions starting with use will be treated as a hook. Commented Jan 31, 2022 at 12:58

1 Answer 1

1

It's the first rule of using react hooks

Only Call Hooks at the Top Level

https://reactjs.org/docs/hooks-rules.html

You need to move that to the top level of your component. If you need to use the state value addCredit you can either pass it in as an argument or if the function is defined within the component, you can use it in scope e.g.

const MyComponent = () => { const [addCredit, setAddCredit] = useState(); async function ConfirmFunction(credit, userID, operation) { return whateverFetchClient.fetch( "/credit/add?userId=" + userID + "&amount=" + credit + "&type=" + operation ); } } 
Sign up to request clarification or add additional context in comments.

2 Comments

I change it but did not work. I edited my question, can you look at it?
useFetch is still a hook, you need to move that one too or use a way to fetch it asynchronously like I had in my example

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.