Skip to content

Latest commit

 

History

History
102 lines (72 loc) · 2.65 KB

useGlobalEvent.md

File metadata and controls

102 lines (72 loc) · 2.65 KB

useGlobalEvent

Accepts an event name to be attached to the window global object, then returns a callback setter for that event.

Why? 💡

  • takes care of adding a listener for a given event to the window object
  • takes care of removing the listener when the component will unmount

Basic Usage:

useGlobalEvent returns a callback setter for the defined event to be immediately invoked.

Please note: the callback setter is only meant to change the callback reference, it does not cause the component rerender nor not be invoked asynchronously.

import { useState } from 'react';
import { useGlobalEvent } from 'beautiful-react-hooks'; 

const TestComponent = () => {
  const [widowWidth, setWindowWidth] = useState(window.innerWidth);
  const onWindowResize = useGlobalEvent('resize');
  
  onWindowResize((event) => {
    setWindowWidth(window.innerWidth);
  });
  
   return (
     <DisplayDemo>
       Current window width: {widowWidth}
     </DisplayDemo>
   );
};

<TestComponent />

Options:

Since useGlobalEvent uses addEventListener under the hood, it's possible to specify the listener characteristics by passing an options object as second parameter.

import { useState } from 'react';
import { useGlobalEvent } from 'beautiful-react-hooks'; 

const TestComponent = () => {
  const [widowWidth, setWindowWidth] = useState(window.innerWidth);
  const options = { capture: true, passive: true, once: true };
  const onWindowResize = useGlobalEvent('resize', options);
  
  onWindowResize((event) => {
    setWindowWidth(window.innerWidth);
  });
  
   return (
     <DisplayDemo>
       Current window width: {widowWidth}
     </DisplayDemo>
   );
};

<TestComponent />

Defining the callback:

The third parameter allow to define the callback avoiding the use of the returned callback setter.

import { useState } from 'react';
import { useGlobalEvent } from 'beautiful-react-hooks'; 

const TestComponent = () => {
  const [widowWidth, setWindowWidth] = useState(window.innerWidth);
  
  useGlobalEvent('resize', null, (event) => {
    setWindowWidth(window.innerWidth);
  });
  
  return (
    <DisplayDemo>
     Current window width: {widowWidth}
    </DisplayDemo>
  );
};

<TestComponent />

Mastering the hooks

✅ When to use

  • If in need to perform a function every x number of milliseconds regardless the component re-renders

🛑 What not to do

  • You can't use the returned callback setter asynchronously, it will not have any effect but changing the callback possibly leading to bugs in your code