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 in JavaScript to limit how often it runs?

Asked on Mar 09, 2026

Answer

Debouncing a function in JavaScript involves ensuring that it is only executed after a specified delay period has passed since the last time it was invoked. This is useful for optimizing performance in scenarios like window resizing or input events.
<!-- BEGIN COPY / PASTE -->
        function debounce(func, delay) {
            let timeoutId;
            return function(...args) {
                clearTimeout(timeoutId);
                timeoutId = setTimeout(() => {
                    func.apply(this, args);
                }, delay);
            };
        }

        // 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: "func" (the function to debounce) and "delay" (the time in milliseconds to wait before invoking "func").
  • "timeoutId" is used to store the ID of the timeout, allowing it to be cleared if the function is called again before the delay period ends.
  • The "apply" method ensures that the original function's context and arguments are preserved.
  • In the example, "handleResize" is debounced with a 300ms delay, meaning it will only execute if the window resize event stops firing for 300ms.
✅ Answered with JavaScript best practices.
← Back to All Questions

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