JavaScript Q&A Logo
JavaScript Q&A Part of the Q&A Topic Learning Network
Real Questions. Clear Answers.
Ask any question about JavaScript here... and get an instant response.
Q&A Balloon Q&A Logo
Post this Question & Answer:

How can I debounce a function to limit how often it runs in response to a frequently fired event?

Asked on Mar 17, 2026

Answer

Debouncing is a technique to limit how often a function is executed, especially useful for events that fire frequently, like window resizing or keypresses. Here's how you can implement a debounce function in JavaScript.
<!-- BEGIN COPY / PASTE -->
        function debounce(func, wait) {
            let timeout;
            return function(...args) {
                const context = this;
                clearTimeout(timeout);
                timeout = setTimeout(() => func.apply(context, args), wait);
            };
        }

        // Example usage:
        const handleResize = () => {
            console.log('Window resized');
        };

        window.addEventListener('resize', debounce(handleResize, 300));
        <!-- END COPY / PASTE -->
Additional Comment:
  • The "debounce" function takes two parameters: the function to debounce ("func") and the delay in milliseconds ("wait").
  • It returns a new function that, when invoked, clears the previous timeout and sets a new one.
  • The "handleResize" function will only execute 300 milliseconds after the last "resize" event.
  • This technique helps improve performance by reducing the number of times the function is called.
✅ Answered with JavaScript best practices.
← Back to All Questions

Q&A Network
Real Questions. Clear Answers.
JavaScript
Ask Questions / Get Answers about JavaScript!
Monetization
Ask Questions / Get Answers about Ad & Monetization!
Networking
Ask Questions / Get Answers about Networking!
Sound Design
Ask Questions / Get Answers about Sound Design!
Film Production
Ask Questions / Get Answers about Film Production!
Chatbots
Ask Questions / Get Answers about Chatbots!
AI Audio
Ask Questions / Get Answers about AI Audio!
Bootstrap
Ask Questions / Get Answers about Bootstrap!
Photography
Ask Questions / Get Answers about Photography!
AI Business
Ask Questions / Get Answers about AI Business!
AI Education
Ask Questions / Get Answers about AI Education!
Creative Writing
Ask Questions / Get Answers about Creative Writing!
Data Science
Ask Questions / Get Answers about Data Science!
AI Writing
Ask Questions / Get Answers about AI Writing!
Animation
Ask Questions / Get Answers about Animation!
AI Design
Ask Questions / Get Answers about AI Design!
AI Images
Ask Questions / Get Answers about AI Images!
WordPress
Ask Questions / Get Answers about WordPress!
AI Coding
Ask Questions / Get Answers about AI Coding!
AI Ethics
Ask Questions / Get Answers about AI Ethics!
Digital Burnout
Ask Questions / Get Answers about Digital Burnout!
IoT
Ask Questions / Get Answers about IoT!
Podcasting
Ask Questions / Get Answers about Podcasting!
Performance
Ask Questions / Get Answers about Web Vitals!
AI Marketing
Ask Questions / Get Answers about AI Marketing!
CSS
Ask Questions / Get Answers about CSS!
Nursing
Ask Questions / Get Answers about Nursing!
AI Video
Ask Questions / Get Answers about AI Video!
Motion Graphics
Ask Questions / Get Answers about Motion Graphics!
Illustration
Ask Questions / Get Answers about Illustration!
Robotics
Ask Questions / Get Answers about Robotics!
HTML
Ask Questions / Get Answers about HTML!
Business Finance
Ask Questions / Get Answers about Business Finance!
SEO
Ask Questions / Get Answers about SEO!
DevOps
Ask Questions / Get Answers about DevOps!
Quantum
Ask Questions / Get Answers about Quantum Computing!
AI
Ask Questions / Get Answers about AI!
Web Hosting
Ask Questions / Get Answers about Hosting!
Social Media Psychology
Ask Questions / Get Answers about Social Media Psychology!
Web Languages
Ask Questions / Get Answers about Web Languages!
Analytics
Ask Questions / Get Answers about Analytics!
Video Editing
Ask Questions / Get Answers about Video Editing!
MobileDev
Ask Questions / Get Answers about Mobile Developement!
VR & AR
Ask Questions / Get Answers about VR & AR!
Cloud Computing
Ask Questions / Get Answers about Cloud Computing!
UI/UX Design
Ask Questions / Get Answers about UI/UX Design!
Web Development
Ask Questions / Get Answers about Web Development!
Tailwind
Ask Questions / Get Answers about Tailwind!
Cybersecurity
Ask Questions / Get Answers about Cybersecurity!
Graphic Design
Ask Questions / Get Answers about Graphic Design!
3D Design
Ask Questions / Get Answers about 3D Design!
Security
Ask Questions / Get Answers about Website Security!