debounce는 JavaScript 및 React의 기술로, 함수 반복을 빠르게 중지하고 지정된 시간 후에 함수를 실행합니다. 특히 사용자가 입력이나 스크롤과 같은 작업을 수행할 때 성능을 향상시키는 데 주로 사용됩니다.
Debounce는 기본적으로 타이머를 생성하며, 지정된 시간 내에 동일한 기능이 반복적으로 실행되면 마지막 기능을 실행하기 전에 나머지 기능을 취소합니다. 예를 들어, 검색창에 입력하는 동안 서버에 API 호출을 수행하려면 키를 누를 때마다 서버를 호출하는 대신 입력이 완료된 후 지정된 시간 후에 API 호출을 수행할 수 있습니다. 이는 서버 부하를 줄이고 애플리케이션 성능을 향상시킵니다.
디바운스 기능은 만들기가 매우 쉽습니다.
function debounce(func, delay) { let timeoutId; return function(...args) { clearTimeout(timeoutId); timeoutId = setTimeout(() => { func.apply(this, args); }, delay); }; }
위의 디바운스 함수는 다음을 수행합니다.
사용자가 입력을 마쳤을 때 검색창에 API 호출을 한다고 가정해 보겠습니다.
function handleSearch(query) { console.log("Searching for:", query); // এখানে API কল হবে } const debouncedSearch = debounce(handleSearch, 500); // 500ms delay // Input field এ টাইপ করার সাথে সাথে debounce ফাংশন কাজ করবে document.getElementById('searchInput').addEventListener('input', function(event) { debouncedSearch(event.target.value); });
여기서 debouncedSearch 함수는 500밀리초를 기다린 후 함수를 호출하므로 여러 키를 눌러도 서버에 여러 요청이 전송되지 않습니다.
React 애플리케이션에서 디바운스 기능은 일반적으로 useEffect 후크와 함께 사용됩니다. 예:
import React, { useState, useEffect } from 'react'; function SearchComponent() { const [query, setQuery] = useState(''); const [debouncedQuery, setDebouncedQuery] = useState(query); // useEffect to handle debounced query update useEffect(() => { const timer = setTimeout(() => { setDebouncedQuery(query); }, 500); // 500ms delay // Cleanup the timeout when query changes return () => { clearTimeout(timer); }; }, [query]); useEffect(() => { if (debouncedQuery) { console.log("Searching for:", debouncedQuery); // এখানে API কল হবে } }, [debouncedQuery]); return ( <input type="text" value={query} onChange={(e) => setQuery(e.target.value)} placeholder="Search..." /> ); } export default SearchComponent;
이 예에서는 사용자가 입력하면 쿼리 상태가 업데이트됩니다. 그러나 debouncedQuery 상태는 사용자가 입력을 중지한 500밀리초 후에만 업데이트됩니다. 결과적으로 API 호출은 여러 번이 아니라 필요할 때만 이루어집니다.
Debounce 기술은 JavaScript와 React의 성능을 향상시키는 효과적인 방법입니다. 이는 이벤트에 대한 불필요한 다중 호출을 피해야 하는 검색 엔진, 양식 유효성 검사 및 스크롤 이벤트에 특히 중요합니다.
위 내용은 JavaScript 및 React에서 Debounce 사용에 대한 자세한 토론의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!