Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Using `useLocation().search` in useEffect without infinite loop

I can't figure out a way to use query inside of useEffect without an infinite loop.

const query = new URLSearchParams(useLocation().search);

useEffect(() => {
  query.forEach((value, field) => {
    ...
  }
 }, [query]);

Any ideas?

like image 338
n8tron Avatar asked Sep 02 '25 16:09

n8tron


1 Answers

You're creating a new instance of URLSearchParams on every render (which is an object type and therefore has a different identity on each render), so the useEffect will run on every render (causing an infinite loop if the useEffect triggers a rerender).

Instead you can either move the definition of query into a useMemo call or just define query in the useEffect if it's not used elsewhere.

For example:

const { search } = useLocation();

const query = useMemo(() => new URLSearchParams(search), [search]);

useEffect(() => {
  query.forEach((value, field) => {
    ...
  }
 }, [query]);

or

const { search } = useLocation();

useEffect(() => {
  const query = new URLSearchParams(search);
  query.forEach((value, field) => {
    ...
  }
 }, [search]);
like image 63
Henry Woody Avatar answered Sep 04 '25 04:09

Henry Woody