1. Promise とは何ですか?
2. なぜ Promise が存在するのでしょうか?Promise は、非同期プログラミングで使用されるコールバック メカニズムのいくつかの問題を解決するために作成されました。
コールバック地獄: Promise はネストされたコールバックを .then().then()… に変換できるため、コードの記述と読み取りがより直感的になります。
3つのPromise共通API
4つのPromiseの一般的な使用法
.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 秒後に表示されます)
//デモ 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 のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
オペレーティング システム: Win7 64 ビット Ultimate Edition MySQL ...
目次1. 遅いところはどこですか? 2. 不要なデータをクエリしましたか? 1. 不要なレコードをク...
1. 動的コンポーネント <!DOCTYPE html> <html> &l...
今日、新しい技を学びました。あまりやったことがなかったので、今まで知りませんでした...目的: リン...
SQL を使用してデータを抽出する場合、テーブル内で重複した値に遭遇することがよくあります。たとえ...
ハイパーリンクの下線を削除するには、スタイルシート CSS を使用する必要があります。当面は CSS...
仮想マシン内のUbuntu 18.04がネットワークに接続できない問題の解決策は次のとおりですVMw...
フレームセットと本文は同じレベルにあるため、本文にフレームセットを配置することはできません。まずペー...
フォームの送信方法をまとめると次のようになります。 1. 送信ボタンを使用して送信します。送信ボタン...
1. psshを確認してインストールします。yum list pssh 2. キーレスログインが設定...
突然、MySQLにログインすると、アクセスが拒否されたか、データベースに接続できないと表示されました...
仮想マシンを初めて使用する方や、仮想マシンに Linux をインストールしたばかりの方は、システムが...
目次1. ダウンロード2. 展開3. Nginxログ関連の設定4. ファイルダウンローダーとして n...
製品デザインのプロセスにおいて、デザイナーは常に写真を非常に美しくすることを好みます。仮想ページのコ...
SQL 左結合、右結合、内部結合、自然結合 さまざまな結合の概要SQL には、左結合、右結合、内部結...