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データベースの基礎知識

推薦する

Vue.jsはカレンダー機能を実装します

この記事では、カレンダー機能を実装するためのVue.jsの具体的なコードを例として紹介します。具体的...

Linux のハードリンクとソフトリンクの区別

Linux には、2 種類のファイル接続があります。1 つは Windows のショートカットに似て...

Nginx で HTTPS 証明書を構成する詳細なプロセス

1. HttpとHttpsの違いHTTP: インターネットで最も広く使用されているネットワーク プロ...

Ubuntu に MySQL 5.7 をインストールし、データ ストレージ パスを構成する方法

1. MySQLをインストールするこの記事はAPT経由でインストールされており、インストールされてい...

MySQLで時間を判定条件として使用する方法

背景: 開発プロセスでは、現在の月、現在の日、現在の時間、今後数日など、時間を判断条件としてデータを...

フロントエンドの状態管理(パート2)

目次1. 再出発1.1. ストア(司書) 1.2. 状態(書籍) 1.3. アクション(図書貸出リス...

MySQL 論理バックアップとリカバリ テストの概要

目次1. データベース論理バックアップとはどのようなバックアップですか? 2. よく使われる論理バッ...

Dockerを使用してSpringBootプロジェクトをデプロイする方法

Docker テクノロジの開発により、マイクロサービスの実装にさらに便利な環境が提供されます。Doc...

vsftpd ユーザーが ssh 経由でログインすることを禁止する方法

序文vsftp は使いやすく安全な FTP サーバー ソフトウェアです。システムユーザーまたは仮想ユ...

MySQL シリーズ 8 MySQL サーバー変数

チュートリアルシリーズMySQL シリーズ: MySQL リレーショナル データベースの基本概念My...

Angularルーティングサブルートの詳細な説明

目次1. サブルート構文2. 例1. 2つの新しいコンポーネントを作成し、その内容を変更する2. ル...

HTML タグ sup と sub の応用の紹介

HTML タグ: 上付き文字HTML では、<sup> タグは上付き文字のテキストを定義...

Vant Uploaderは1枚以上の写真をアップロードするコンポーネントを実装します

この記事では、1枚以上の写真をアップロードするためのVant Uploaderコンポーネントを紹介し...

vue+tsは要素のマウスドラッグの効果を実現します

この記事の例では、要素のマウスドラッグ効果を実現するためのvue+tsの具体的なコードを参考までに共...

WeChatミニプログラムをTencent Mapsに接続する2つの方法

最近、WeChat アプレットを作成しているのですが、いくつか問題が発生しました。インターネットでい...