JavaScript Promise の徹底解説

JavaScript Promise の徹底解説

1. Promise とは何ですか?

Promise オブジェクトはコンテナのようなものです。特定の操作を実行するコードが含まれています。コードが実行されると、2 つのコールバック関数が実行されます。1 つは成功した操作 (解決) のコールバック関数で、もう 1 つは失敗した操作 (拒否) のコールバック関数です。

2. なぜ Promise が存在するのでしょうか?

Promise は、非同期プログラミングで使用されるコールバック メカニズムのいくつかの問題を解決するために作成されました。

  • コールバック地獄

コールバック地獄: Promise はネストされたコールバックを .then().then()… に変換できるため、コードの記述と読み取りがより直感的になります。

  • 難しいエラー処理: エラー処理ではコールバックよりも Promise の方が明確で直感的です
  • 複数の非同期操作を同時に実行するコードを書くのは難しいですが、Promiseを使えば簡単にこの状況に対処できます。

3つのPromise共通API

  • promise の .then() メソッドが実行された後、これを実行できます。これには、成功時のコールバック関数と失敗時のコールバック関数の 2 つのパラメーターがあります。
  • 解決promise.resolveメソッドを使用して、promiseオブジェクトを素早く返します。
  • 拒否するpromise.rejectメソッドを使用して、promiseオブジェクトを素早く返します。
  • all 複数の並列非同期操作を同時に実行します。

4つのPromiseの一般的な使用法

1 コールバック地獄を解決するには?

.then() は値を返さない関数なので、Promise チェーンは継続されなくなります。この時点では、後で .then() を呼び出しても効果はありません。

Promise.resolve('foo').then(関数{
  console.log(s);
}).then(関数{
  // 実行されない
  console.log(s);
});

.then()には戻り値関数があり、Promiseチェーンを継続することができます。

Promise.resolve('foo').then(関数{
  console.log(s);
  s + 'bar' を返します。
}).then(関数{
  console.log(s);
});

// フー
// フーバー

.then() には値を返す関数があり、戻り値は別の Promise オブジェクトであり、これによっても Promise が続行されます。前者との違いは、.then() を再度呼び出すと非同期操作がトリガーされる可能性があるため、次のラウンドの resolve() がすぐにはトリガーされないことです。

Promise.resolve('foo').then(関数{
  新しい Promise を返します ((resolve, reject) => {
      console.log(s);
      タイムアウトを設定する(() => {
          解決(s + 'bar')
        }, 1000);
    });
}).then(関数{
  console.log(s);
});


// フー
// foobar ("foo" が表示されてから 1 秒後に表示されます)

2 Promise.all() は戻り値の同時同期受信を実装します アプリケーションシナリオの説明 (複数のインターフェースから同時にデータを呼び出し、フロントエンドでデータを処理する必要があるため、すべてのインターフェースがデータを返すのを待ってから操作する必要があります。)

//デモ
promise1 を const として返す。
定数promise2 = 42;
const promise3 = 新しい Promise((resolve, 拒否) => {
  setTimeout(解決、100、'foo');
});
 
Promise.all([promise1, promise2, promise3]).then((値) => {
  console.log(値);
});
// 期待される出力: 配列 [3, 42, "foo"]

Promise.all() と sync await の違い

//sync 操作時間を2秒待機する async function Index2() {
      コンソール.time()
      const p1 = 新しい Promise((resolve, reject) => {を待つ
        console.log('ここがp1です')
        タイムアウトを設定する(() => {
          解決('p1の戻り値です')
        }, 1000)
      })
      const p2 = 新しい Promise((resolve, reject) => {を待つ
        console.log('ここがp2です')
        タイムアウトを設定する(() => {
          解決('p2の戻り値です')
        }, 1000)
      })
      コンソールログ(p1)
      コンソール.log(p2) 
      コンソール.timeEnd()
   }
    インデックス2();

ここに画像の説明を挿入

// 呼び出しを実装するには Promise.all() を使用します。操作時間1秒関数Index() {
      コンソール.time()
      const p1 = new Promise((resolve, deny) => {
        console.log('ここがp1です')
        タイムアウトを設定する(() => {
          解決('p1の戻り値です')
        }, 1000)
      })
      const p2 = new Promise((resolve, deny) => {
        console.log('ここがp2です')
        タイムアウトを設定する(() => {
          解決('p2の戻り値です')
        }, 1000)
      })
      Promise.all([p1, p2]).then((val) => {
        コンソール.log(値)
        コンソール.timeEnd()
      })
}

ここに画像の説明を挿入

要約する

この記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。

以下もご興味があるかもしれません:
  • JavaScript における Promise の詳細な説明
  • フロントエンドJavaScriptの約束
  • JS 9 Promise 面接の質問
  • JS の Promise に中止関数を追加する方法
  • JavaScriptのPromiseを徹底的に理解する

<<:  デザイナーが再びハマーの公式サイトに不満を述べる

>>:  MySQLデータベースの基礎知識

推薦する

Nginx を使用してポート転送 TCP プロキシを実装する例

目次需要背景Nginx を使用する理由は何ですか? Nginx によるポート転送依存関係をインストー...

QQtabBar による CSS 命名仕様 BEM の詳細な紹介

QQtabBar の BEMまず、BEMとはどういう意味でしょうか? BEM は、ブロック、要素、修...

JavaScript セレクター関数 querySelector および querySelectorAll

目次1. querySelectorは単一の要素を照会する1. ドキュメントインスタンスの呼び出し2...

HTMLの基礎を徹底解説(第1部)

1. WEBを理解するWeb ページは主にテキスト、画像、ハイパーリンクなどの要素で構成されていま...

MacBook 向け Python 3.7 インストール チュートリアル

MacBookにpython3.7.0をインストールする詳細な手順は、参考までに記録されています。具...

Linux スワップ パーティション (詳細説明)

目次リナックス1. SWAPとは2. swappiness は何を調節しますか? 3. スワップ操作...

MySQLは「order by」がどのように機能するかを簡単に理解します

並べ替えの場合、order by は非常に頻繁に使用するキーワードです。インデックスに関するこれまで...

Webpackプラグインを書いてnpmに公開するための80行のコード

1. はじめに最近、 Webpackの原理を勉強しています。これまでは Webpack の設定方法し...

Linuxオンラインソフトウェアgccをオンラインでインストールする方法

Linux オンラインインストール関連コマンド: yum install: すべてインストールyum...

Vue cli開発に基づく外部コンポーネントVantのデフォルトスタイルの変更の詳細な説明

目次序文1. 少ない2. コンポーネントをインポートする3. 設定ファイルを変更するステップ1: l...

Vue3.0 + TypeScript + Vite初体験の詳しい説明

目次プロジェクトの作成プロジェクト構造メイン.jsアプリ.vue:設定コンポジションAPI参照反応的...

Windows システムに MySQL を素早くインストールして展開する方法 (グリーンの無料インストール バージョン)

まずは緑色の無料インストール版のMySQLをダウンロードします。任意のフォルダに入れて構いません。今...

mysql8.0.11データディレクトリ移行の実装

mysql のデフォルトのストレージ ディレクトリは/var/lib/mysql/です。以下は、デフ...

MySQL テーブル削除操作の実装 (delete、truncate、drop の違い)

この記事では主に、MySQL でテーブルを削除する 3 つの操作、つまり delete ステートメン...

linxu での Svn ワンクリック インストール シェル スクリプトの詳細な説明

#!/bin/bash #SVNをダウンロード yum -y サブバージョンをインストールします ...