We use cookies to enhance your browsing experience.
Listen for media query matches.
import { useState, useEffect } from 'react'; export function useMediaQuery(query: string): boolean { const [matches, setMatches] = useState(false); useEffect(() => { const media = window.matchMedia(query); if (media.matches !== matches) { setMatches(media.matches); } const listener = () => setMatches(media.matches); window.addEventListener('resize', listener); return () => window.removeEventListener('resize', listener); }, [matches, query]); return matches; }
We use cookies to enhance your experience and serve personalized ads.