Home > Web Front-end > JS Tutorial > How Can I Ensure a Function Called with `setInterval` Executes Only Once?

How Can I Ensure a Function Called with `setInterval` Executes Only Once?

Patricia Arquette
Release: 2024-12-04 01:54:11
Original
441 people have browsed it

How Can I Ensure a Function Called with `setInterval` Executes Only Once?

Managing Scheduled Functions with setInterval and clearInterval

Consider the following code fragment:

function doKeyDown(event) {
    switch (event.keyCode) {
        case 32:
            /* Space bar was pressed */
            if (x == 4) {
                setInterval(drawAll, 20);
            }
            else {
                setInterval(drawAll, 20);
                x += dx;
            }
            break;
    }
}
Copy after login

The goal is to call the drawAll function only once, not create a loop that repeatedly invokes it.

Using clearInterval to Stop Recurring Execution

setInterval establishes a recurring timer that calls the specified function periodically. To cease its execution, we can utilize clearInterval. Here's how it works:

var handle = setInterval(drawAll, 20);

// When you want to stop it:
clearInterval(handle);
handle = 0; // Indication of an uncleared interval
Copy after login

On browsers, the handle is guaranteed to be a non-zero numerical value. Thus, setting handle = 0 serves as a convenient flag to indicate that the interval has been cleared.

Scheduling a One-time Function Call

If the intention is to execute a function only once, consider using setTimeout instead. This function schedules a function to be invoked after a specified time interval but doesn't continue firing it thereafter. It also returns a handle for potential cancellation.

setTimeout(drawAll, 20);
Copy after login

The above is the detailed content of How Can I Ensure a Function Called with `setInterval` Executes Only Once?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template