"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > JavaScript의 디바운싱과 제한: 사용해야 하는 시기와 이유

JavaScript의 디바운싱과 제한: 사용해야 하는 시기와 이유

2024-11-02에 게시됨
검색:380

Debouncing vs Throttling in JavaScript: When and Why You Should Use Them

JavaScript는 웹 앱을 동적이고 대화형으로 만드는 데 환상적이지만 자체적으로는 잘 처리할 수 없는 한 가지가 있습니다. 바로 빈번한 이벤트입니다. 창 크기 조정, 스크롤, 검색창 입력 등을 생각해 보세요. 제대로 관리하지 않으면 앱에 이벤트 트리거가 넘쳐 속도가 느려지고 사용자 경험이 느려질 수 있습니다. 이것이 디바운싱제한이 필요한 곳입니다. 이러한 기술을 사용하면 특정 기능이 실행되는 빈도를 제어하여 앱의 속도와 반응성을 유지할 수 있습니다.

이 글에서는 디바운싱제한을 분석하고, 언제 사용해야 하는지 보여주고, 실제로 작동하는 모습을 볼 수 있는 실제 사례를 제공합니다. 필수적인 JavaScript 성능 최적화 기술을 자세히 살펴보겠습니다!

디바운싱이란 무엇입니까?

작동 방식

답장을 시작하기 전에 누군가가 말을 마칠 때까지 기다리는 것처럼 반송을 취소하는 것을 생각해 보세요. 누군가가 계속해서 대화를 방해하는 상황을 겪어 본 적이 있다면, 그 아이디어를 얻으실 수 있을 것입니다! 디바운싱의 핵심 개념은 이벤트가 마지막으로 트리거된 이후 지정된 시간이 지날 때까지 함수 실행을 지연한다는 것입니다.

간단히 말하면 이벤트(예: 사용자 입력)가 계속 빠르게 발생하는 경우 디바운싱을 통해 사용자가 특정 기간 동안 중지한 후에만 관련 기능(예: 검색어)이 실행됩니다.

디바운싱을 사용해야 하는 경우

잦은 사용자 입력으로 인한 과도한 함수 호출을 제한하려는 경우 디바운싱을 사용해야 합니다. 전형적인 예는 검색창이 있고 사용자가 입력할 때마다 API를 호출하려는 경우입니다. 디바운싱하지 않으면 키를 누를 때마다 API가 호출되어 서버에 불필요한 부하가 발생할 수 있습니다. 디바운싱을 사용하면 사용자가 입력을 중지한 후에만 API가 호출됩니다.

코드에서의 디바운싱

function debounce(func, delay) {
    let timeoutId;
    return function(...args) {
        clearTimeout(timeoutId);
        timeoutId = setTimeout(() => func.apply(this, args), delay);
    };
}

// Usage
const searchInput = document.getElementById('search');
searchInput.addEventListener('input', debounce(() => {
    console.log('API call made!');
}, 300)); // Only executes 300ms after the last keystroke

이 예에서 디바운스 기능은 사용자가 입력을 중지한 후 300밀리초 후에만 API 호출이 발생하도록 보장합니다.

조절이란 무엇입니까?

디바운싱과의 차이점

이제 제한에 대해 이야기해 보겠습니다. 디바운싱이 채팅이 멈출 때까지 응답을 기다리고 있는 경우, 제한은 얼마나 많은 자동차가 기다리고 있는지에 관계없이 몇 초마다 한 대의 자동차만 통과하도록 하는 교통 경찰과 같습니다. 이벤트가 반복적으로 트리거되더라도 설정된 기간마다 최대 한 번 함수가 호출되도록 보장합니다.

조절을 사용해야 하는 경우

시간이 지나도 일관된 실행을 보장해야 하는 경우 제한을 사용하는 것이 좋습니다. 예를 들어 사용자가 페이지를 아래로 스크롤하면 스크롤 이벤트가 초당 수십 번씩 트리거될 수 있습니다. 제한하지 않으면 앱이 모든 이벤트를 처리하려고 시도하면서 속도가 느려질 수 있습니다. 조절은 스크롤 이벤트 핸들러가 실행될 수 있는 빈도를 제한하여 성능을 향상시킵니다.

코드 제한

function throttle(func, limit) {
    let lastCall = 0;
    return function(...args) {
        const now = Date.now();
        if (now - lastCall >= limit) {
            lastCall = now;
            func.apply(this, args);
        }
    };
}

// Usage
window.addEventListener('scroll', throttle(() => {
    console.log('Scroll event!');
}, 1000)); // Executes at most once every 1000ms

여기서 스로틀 기능은 스크롤 이벤트 핸들러가 1000밀리초마다 한 번만 실행되도록 하여 앱이 과부하되지 않도록 합니다.

실제 사례

이러한 기술을 보다 실용적인 맥락에 적용해 보겠습니다. 사용자가 검색창에 입력하는 React 앱을 구축한다고 가정해 보겠습니다. API 호출로 인해 서버가 넘쳐나는 것을 방지하기 위해 입력 이벤트를 디바운스할 수 있습니다. 또는 사용자가 페이지에서 얼마나 멀리 스크롤했는지 추적하는 경우 제한을 사용하여 성능을 최적화할 수 있습니다.

React에서의 디바운싱

import { useState } from 'react';

function SearchComponent() {
    const [query, setQuery] = useState('');

    const handleSearch = debounce((value) => {
        // API call with the value
        console.log('Searching for:', value);
    }, 300);

    return (
         {
                setQuery(e.target.value);
                handleSearch(e.target.value);
            }}
        />
    );
}

스크롤 이벤트 조절

import { useEffect } from 'react';

function ScrollTracker() {
    useEffect(() => {
        const handleScroll = throttle(() => {
            console.log('Scrolling...');
        }, 1000);

        window.addEventListener('scroll', handleScroll);
        return () => window.removeEventListener('scroll', handleScroll);
    }, []);

    return 
Scroll to see throttling in action!
; }

성능 최적화 모범 사례

디바운싱과 스로틀링: 선택 시기

다음은 간단한 경험 법칙입니다.

  • 디바운싱은 사용자가 작업을 중단할 때까지 기다리고 싶을 때 완벽합니다. 예를 들어 검색창에 입력하는 경우입니다.
  • 제한은 시간이 지남에 따라 일관되고 주기적인 실행을 보장하려는 경우 가장 잘 작동합니다. 창을 스크롤하거나 크기를 조정하는 데 이상적입니다.

어떤 종류의 이벤트를 다루고 있고 얼마나 자주 발생하는지 알면 작업에 적합한 기술을 선택할 수 있습니다.

결론

자바스크립트에서 자주 발생하는 이벤트를 제어하는 ​​것은 성능 최적화에 필수적이며, 디바운싱조절 모두 강력한 솔루션을 제공합니다. 각 항목을 언제 사용해야 하는지 이해하면 검색 입력 처리, 창 크기 조정, 스크롤 이벤트 관리 등 웹 애플리케이션을 더욱 원활하고 응답성이 향상되도록 만들 수 있습니다.

다음번에 너무 많은 이벤트로 인해 앱이 정체되는 것을 발견하면 스스로에게 물어보세요. 디바운싱해야 할까요, 아니면 제한해야 할까요? 그렇게 하시면 정말 기뻐하실 겁니다!

시도해 볼 준비가 되셨나요? 다음 번에 프로젝트 작업을 할 때 이 기술을 사용해 보세요. 모든 것이 얼마나 부드러워졌는지 놀라실 겁니다!

릴리스 선언문 이 기사는 https://dev.to/paharihacker/debounce-vs-throttling-in-javascript-when-and-why-you-should-use-them-1l09?1에서 재현됩니다. 침해가 있는 경우, 문의: Study_golang@163 .comdelete
최신 튜토리얼 더>
  • EchoAPI와 불면증: 실제 사례를 통한 종합 비교
    EchoAPI와 불면증: 실제 사례를 통한 종합 비교
    풀 스택 개발자로서 저는 API 디버깅, 테스트, 문서화를 위한 최고의 도구를 보유하는 것이 얼마나 중요한지 알고 있습니다. EchoAPI와 Insomnia는 두 가지 뛰어난 옵션으로 각각 고유한 기능과 기능을 갖추고 있습니다. 이러한 도구를 안내하고, 기능과 이점을 ...
    프로그램 작성 2024-11-02에 게시됨
  • 이동 시간 및 기간 | 프로그래밍 튜토리얼
    이동 시간 및 기간 | 프로그래밍 튜토리얼
    소개 이 랩의 목표는 Go의 시간 및 기간 지원에 대한 이해도를 테스트하는 것입니다. 시간 아래 코드에는 Go에서 시간과 기간을 사용하는 방법에 대한 예가 포함되어 있습니다. 그러나 코드의 일부가 누락되었습니다. 귀하의 임무는 예상대로 작...
    프로그램 작성 2024-11-02에 게시됨
  • 호이스팅 면접 질문 및 답변
    호이스팅 면접 질문 및 답변
    1. 자바스크립트에서 호이스팅이란 무엇인가요? 답변: 호이스팅은 변수와 함수에 메모리가 할당되는 실행 컨텍스트 생성 단계의 프로세스입니다. 이 프로세스 동안 변수에 대한 메모리가 할당되고 변수에는 정의되지 않은 값이 할당됩니다. 함수의 경우 전체 함수 ...
    프로그램 작성 2024-11-02에 게시됨
  • JavaScript의 DOM(문서 개체 모델) 이해
    JavaScript의 DOM(문서 개체 모델) 이해
    안녕하세요, 놀라운 JavaScript 개발자 여러분? 브라우저는 스크립트(특히 JavaScript)가 웹 페이지 레이아웃과 상호 작용할 수 있도록 하는 DOM(문서 개체 모델)이라는 프로그래밍 인터페이스를 제공합니다. 페이지의 구성 요소를 개체로 배열...
    프로그램 작성 2024-11-02에 게시됨
  • SPRING BATCH로 프로그래밍 시작
    SPRING BATCH로 프로그래밍 시작
    Introduction Dans vos projets personnels ou professionnels, Il vous arrive de faire des traitements sur de gros volumes de données. Le traite...
    프로그램 작성 2024-11-02에 게시됨
  • CSS로 Github 프로필을 돋보이게 만드세요
    CSS로 Github 프로필을 돋보이게 만드세요
    이전에는 Github 프로필을 맞춤 설정할 수 있는 유일한 방법은 사진을 업데이트하거나 이름을 변경하는 것이었습니다. 이는 모든 Github 프로필이 동일해 보이고 이를 사용자 정의하거나 눈에 띄게 하는 옵션이 최소화되었음을 의미합니다. 이후부터 Markdown을 사용...
    프로그램 작성 2024-11-02에 게시됨
  • TypeScript 유틸리티 유형: 코드 재사용성 향상
    TypeScript 유틸리티 유형: 코드 재사용성 향상
    TypeScript는 개발자가 유형을 효과적으로 변환하고 재사용할 수 있는 내장 유틸리티 유형을 제공하여 코드를 더욱 유연하고 DRY하게 만듭니다. 이 기사에서는 TypeScript 기술을 다음 단계로 끌어올리는 데 도움이 되는 Partial, Pick, Omit 및 ...
    프로그램 작성 2024-11-02에 게시됨
  • 텔레그램 window.open(url, &#_blank&#); iOS에서는 이상하게 작동합니다
    텔레그램 window.open(url, &#_blank&#); iOS에서는 이상하게 작동합니다
    텔레그램 봇을 만들고 있는데 미니앱의 일부 정보를 채팅으로 전달하는 옵션을 추가하고 싶습니다. 나는 window.open(url, '_blank');를 사용하기로 결정했습니다. iPhone에서 사용해 보기 전까지는 잘 작동했습니다. 전달하는 대신 공유 기...
    프로그램 작성 2024-11-02에 게시됨
  • 프론트엔드 개발자는 누구인가요?
    프론트엔드 개발자는 누구인가요?
    오늘날 인터넷상의 모든 웹사이트나 플랫폼의 사용자 인터페이스 부분은 프런트 엔드 개발자의 작업 결과입니다. 이들은 사용자 친화적인 인터페이스를 만드는 데 참여하여 사이트의 모양과 기능을 보장합니다. 그렇다면 프론트엔드 개발자는 정확히 누구일까요? 간단하게 설명드리겠습니...
    프로그램 작성 2024-11-02에 게시됨
  • 보존된 CSS 스타일을 사용하여 HTML 콘텐츠를 PDF로 저장하는 방법은 무엇입니까?
    보존된 CSS 스타일을 사용하여 HTML 콘텐츠를 PDF로 저장하는 방법은 무엇입니까?
    CSS가 포함된 HTML 콘텐츠를 PDF로 저장웹 개발에서는 콘텐츠를 다른 형식으로 내보낼 때에도 시각적 미학을 유지하는 것이 중요합니다. 변환 프로세스 중에 CSS 스타일이 손실될 수 있으므로 HTML 요소를 PDF로 저장하려고 할 때 문제가 발생할 수 있습니다.저장...
    프로그램 작성 2024-11-02에 게시됨
  • Print_r()을 사용할 때 왜 팬텀 속성이 DateTime 객체에 추가됩니까?
    Print_r()을 사용할 때 왜 팬텀 속성이 DateTime 객체에 추가됩니까?
    Print_r() DateTime 객체 변경Print_r()는 DateTime 객체에 속성을 추가하여 디버깅 중에 자체 검사를 활성화합니다. PHP 5.3에 도입된 내부 기능의 부작용인 이 동작은 텍스트에 덤프된 인스턴스에 가상 공용 속성을 할당합니다.이러한 속성으로 ...
    프로그램 작성 2024-11-02에 게시됨
  • C의 데이터 구조 및 알고리즘: 초보자에게 친숙한 접근 방식
    C의 데이터 구조 및 알고리즘: 초보자에게 친숙한 접근 방식
    C에서는 데이터 구조와 알고리즘을 사용하여 데이터를 구성, 저장 및 조작합니다. 데이터 구조: 배열: 정렬된 컬렉션, 요소에 액세스하기 위해 인덱스 사용 연결 목록: 포인터를 통해 요소 연결, 동적 길이 지원 스택: FILO(선입선출) 원칙 큐: FIFO(선입선출) 원...
    프로그램 작성 2024-11-02에 게시됨
  • ## `has_key()` 또는 `in`?  Python에서 사전 키를 확인하는 가장 좋은 방법은 무엇입니까?
    ## `has_key()` 또는 `in`? Python에서 사전 키를 확인하는 가장 좋은 방법은 무엇입니까?
    Python에서 사전 키 확인을 위해 'has_key()'와 'in' 중에서 선택 Python 사전의 특정 키, 'has_key()' 및 'in' 모두 실행 가능한 옵션을 제공합니다. 그러나 선호되는 방법은 시간...
    프로그램 작성 2024-11-02에 게시됨
  • AJAX를 사용하여 JSON 데이터를 PHP로 보내는 방법은 무엇입니까?
    AJAX를 사용하여 JSON 데이터를 PHP로 보내는 방법은 무엇입니까?
    Ajax를 사용하여 JSON 데이터를 PHP로 전송하는 방법JSON 형식으로 PHP 스크립트에 데이터를 전달하려면 다음이 중요합니다. AJAX를 사용하여 효과적으로 데이터를 보낼 수 있습니다.JSON 데이터 보내기제공된 코드는 AJAX를 사용하여 JSON 데이터를 보내...
    프로그램 작성 2024-11-02에 게시됨
  • JS: 약속인가, 콜백인가?
    JS: 약속인가, 콜백인가?
    JavaScript의 Promise와 Callback 이해하기 인증 테스트에 대한 주요 질문 및 답변 콜백 함수란 무엇이며 일반 함수와 어떻게 다릅니까? 콜백 함수는 다른 함수에 인수로 전달되고 비동기 작업을 처리하기 위해 호출됩니다. 일...
    프로그램 작성 2024-11-02에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3