Impedire che una funzione venga chiamata troppe volte React-Esempi di codice

Radu TM

Impedire che una funzione venga chiamata troppe volte React

JavaScript di Radu TM June 16, 2022

import React, { useState, useEffect } from 'react';

function useThrottle(fn, threshhold, scope) {
  let lastFnCallTimestamp = Date.now();

  return function throttleWrapper() {
    const now = Date.now();
    if (now - lastFnCallTimestamp < threshhold) return;

    lastFnCallTimestamp = now;
    fn.apply(scope, arguments);
  }
}

// Utilizzo
function MyComponent() {
  const [clicks, setClicks] = useState(0);

  function handleClick() {
    setClicks(clicks + 1);
  }

  const throttledHandleClick = useThrottle(handleClick, 1000);

  return (
    <div onClick={throttledHandleClick}>
      Questo div è stato cliccato {clicks} volte.
    </div>
  );
}

0

46.128

Richieste JavaScript simili

Ultime richieste JavaScript

Esplora gli esempi di codice per categorie