サイトアイコン ITC Media

JavaScriptでsleep機能を実装する|コード実例付き

(最終更新月:2023年11月)

✔以下のような疑問を持つ方に向けて書かれています

「JavascriptでSleep機能はどう実装するの?」

「Sleep関数の書き方や使用例を知りたい」

「JavaScriptにおけるSleepの具体的なコードが見てみたい」

✔当記事で伝える内容

当記事では、JavaScriptでのSleep処理について基本から、効果的な応用方法まで、具体的なコードを交えて詳細に説明します。

ぜひ最後までお付き合いください。

筆者プロフィール

【現職】プロダクトマネージャー

【副業】ブログ(月間20万PV)/YouTube/Web・アプリ制作

「プログラミング × ライティング × 営業」の経験を活かし、30後半からのIT系職へシフト。現在はプロダクトマネージャーとして、さまざまな関係者の間に入り奮闘してます。当サイトでは、実際に手を動かせるWebアプリの開発を通じて、プログラミングはもちろん、IT職に必要な情報を提供していきます。

【当ブログで紹介しているサイト】

当サイトチュートリアルで作成したデモ版日報アプリ

Django × Reactで開発したツール系Webアプリ

✔人に見せても恥ずかしくないコードを書こう

「リーダブルコード」は、わかりやすく良いコードの定義を教えてくれる本です。

  • 見るからにきれいなコードの書き方
  • コードの分割方法
  • 変数や関数の命名規則

エンジニアのスタンダートとすべき基準を一から解説しています。

何回も読むのに値する本なので、ぜひ手にとって読んでみてください。

JavaScript Sleepの基本概念

こちらでは、JavaScriptにおける「Sleep」の基本的な概念についてお伝えしていきます。

「Sleep」について理解することで、プログラムの一時的な停止や遅延処理の実装に役立つでしょう。

はじめに:Sleepとは?

Sleepは、プログラムの実行を一時的に停止させる機能のこと。

多くのプログラミング言語にはこのSleep機能が組み込まれていますが、JavaScriptには標準でこの機能は存在しません。

JavaScriptとSleep:本来の関係

JavaScriptにsleepが存在しない理由は、ブラウザ上で動作する言語として設計されているから。

ページの応答性を維持するためにSleepのような直接的な停止機能は持っていないのです。

しかし、特定の処理を遅延させるための方法はいくつか存在します。

JavaScript Sleep機能作成のアプローチ

こちらでは、JavaScriptでSleep機能を実現するための異なるアプローチについて詳しく解説します。

これらのアプローチを理解することで、シチュエーションに応じた最適なSleep機能の実装が可能です。

ビジーウェイト方式を用いたSleep作成

ビジーウェイトは、特定の時間だけCPUを占有して待機する方法です。

しかし、この方法は非効率的であり、現代のJavaScript開発では推奨されません。

タイマー機能を活用したSleepメソッド

JavaScriptには、非同期処理をサポートするタイマー関数が組み込まれています。

setInterval()を用いた手法

setInterval関数は、指定した時間間隔で関数を繰り返し実行するもの。

この機能を使ってSleepのような動作を模倣できます。

function sleepWithInterval(ms) {
    let start = new Date().getTime();
    let end = start;
    while(end < start + ms) {
        end = new Date().getTime();
    }
}

setTimeout()でのSleep実装

setTimeout関数は、指定した時間が経過した後に関数を一度だけ実行します。

この関数を利用して、非同期のSleepを実現可能です。

function sleepWithTimeout(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}

異なるプログラムアプローチでのSleep実装

こちらでは、異なるプログラムアプローチを用いたSleepの実装方法について詳しく解説します。

これらの方法を理解することで、より効率的かつ適切なSleepの実装が可能です。

Promiseを使ったSleepメソッドの作り方

JavaScriptのES6から導入されたPromiseは、非同期処理をより直感的に扱えるオブジェクトです。

Promiseを使用して、非同期のSleepを実現する方法を紹介します。

function sleep(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}

jQueryを利用したSleep実装

jQueryは、JavaScriptのライブラリのひとつで、非同期処理を簡単に実装できます。

以下は、jQueryのdelayメソッドを使用して、Sleepのような動作を実現する方法です。

$(element).delay(2000).fadeIn();

async/awaitを活用したSleep関数制作

async/awaitは、JavaScriptの非同期処理をより直感的に書くための構文です。

この構文を使用して、非同期のSleepを実現する方法を紹介します。

非同期処理を同期的に書くことができ、コードの可読性が向上するでしょう

async function exampleFunction() {
    console.log('Start');
    await sleep(2000);
    console.log('End after 2 seconds');
}

function sleep(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}

この例では、exampleFunctionを実行すると、’Start’を出力した後、2秒間待機してから’End after 2 seconds’を出力します。

各Sleep実装手法の特性と違い

こちらでは、各Sleep実装手法の特性とその違いについて詳しく解説します。

これらの手法を理解することで、シチュエーションに応じた最適なSleep機能の選択が可能です。

各実装手法の特性まとめ

以下は各実装方法の一覧です。

名前特徴適している場面実例
ビジーウェイトCPUを占有するため非効率的。
一定時間CPUを忙しくさせる。
テストやデモの目的で短期間の遅延が必要な場合。
しかし実際のアプリケーションでは推奨されない。
let start = Date.now();
while (Date.now() < start + 1000);
setInterval/setTimeout非同期処理をサポートするタイマー関数。
指定した時間後に関数を実行。
一定時間後に一度だけ、
または定期的な処理が必要な場合。
setTimeout(() => {
console.log(“Sleep over”);
}, 1000);
Promise非同期処理を直感的に扱えるオブジェクト。複雑な非同期処理の制御が必要な場合。new Promise(resolve =>
setTimeout(resolve, 1000));
jQueryJavaScriptのライブラリ。
非同期処理を簡単に実装。
jQueryを使用している環境で簡単に非同期処理を行いたい場合。$.delay(1000).done(() => {
console.log(“Sleep over”);
});
async/await非同期処理を同期的に書くことができる構文。非同期処理をより読みやすく、同期的に書きたい場合。async function sleep() {
await new Promise(resolve => setTimeout(resolve, 1000));
}

初心者に最適な簡潔な方法:Promiseとawaitの効果的な活用

初心者にとって、非同期処理は難易度が高いトピックのひとつです。

Promiseとasync/awaitを組み合わせることで、非同期処理を簡潔かつ直感的に書けるはず。

この組み合わせは、初心者にとっても理解しやすいため、非同期処理の入門として最適といえるでしょう。

まとめ:JavaScript Sleepの理解と適用

当記事では、JavaScriptでのSleep処理について学習してきました。

JavaScriptには標準でSleep機能が存在しないため、異なるアプローチを用いてこの機能を実現する必要があります。

JavaScript Sleepの活用においては、以下の点を意識すると良いでしょう。

モバイルバージョンを終了