Skip to content

Instantly share code, notes, and snippets.

@zaknesler
Created October 29, 2022 15:49
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save zaknesler/7dbae835b0884b7645135d2477c365d6 to your computer and use it in GitHub Desktop.
Save zaknesler/7dbae835b0884b7645135d2477c365d6 to your computer and use it in GitHub Desktop.
import { useEffect } from 'react'
const useEvent = <T extends keyof WindowEventMap>(
event: T,
handler: (this: Window, ev: WindowEventMap[T]) => any,
options?: boolean | AddEventListenerOptions,
) => {
useEffect(() => {
window.addEventListener(event, handler, options)
return () => window.removeEventListener(event, handler)
}, [event, handler, options])
}
export default useEvent
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment