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 のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
目次需要背景Nginx を使用する理由は何ですか? Nginx によるポート転送依存関係をインストー...
QQtabBar の BEMまず、BEMとはどういう意味でしょうか? BEM は、ブロック、要素、修...
目次1. querySelectorは単一の要素を照会する1. ドキュメントインスタンスの呼び出し2...
1. WEBを理解するWeb ページは主にテキスト、画像、ハイパーリンクなどの要素で構成されていま...
MacBookにpython3.7.0をインストールする詳細な手順は、参考までに記録されています。具...
目次リナックス1. SWAPとは2. swappiness は何を調節しますか? 3. スワップ操作...
並べ替えの場合、order by は非常に頻繁に使用するキーワードです。インデックスに関するこれまで...
1. はじめに最近、 Webpackの原理を勉強しています。これまでは Webpack の設定方法し...
Linux オンラインインストール関連コマンド: yum install: すべてインストールyum...
目次序文1. 少ない2. コンポーネントをインポートする3. 設定ファイルを変更するステップ1: l...
目次プロジェクトの作成プロジェクト構造メイン.jsアプリ.vue:設定コンポジションAPI参照反応的...
まずは緑色の無料インストール版のMySQLをダウンロードします。任意のフォルダに入れて構いません。今...
mysql のデフォルトのストレージ ディレクトリは/var/lib/mysql/です。以下は、デフ...
この記事では主に、MySQL でテーブルを削除する 3 つの操作、つまり delete ステートメン...
#!/bin/bash #SVNをダウンロード yum -y サブバージョンをインストールします ...