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 のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
この記事では、カレンダー機能を実装するためのVue.jsの具体的なコードを例として紹介します。具体的...
Linux には、2 種類のファイル接続があります。1 つは Windows のショートカットに似て...
1. HttpとHttpsの違いHTTP: インターネットで最も広く使用されているネットワーク プロ...
1. MySQLをインストールするこの記事はAPT経由でインストールされており、インストールされてい...
背景: 開発プロセスでは、現在の月、現在の日、現在の時間、今後数日など、時間を判断条件としてデータを...
目次1. 再出発1.1. ストア(司書) 1.2. 状態(書籍) 1.3. アクション(図書貸出リス...
目次1. データベース論理バックアップとはどのようなバックアップですか? 2. よく使われる論理バッ...
Docker テクノロジの開発により、マイクロサービスの実装にさらに便利な環境が提供されます。Doc...
序文vsftp は使いやすく安全な FTP サーバー ソフトウェアです。システムユーザーまたは仮想ユ...
チュートリアルシリーズMySQL シリーズ: MySQL リレーショナル データベースの基本概念My...
目次1. サブルート構文2. 例1. 2つの新しいコンポーネントを作成し、その内容を変更する2. ル...
HTML タグ: 上付き文字HTML では、<sup> タグは上付き文字のテキストを定義...
この記事では、1枚以上の写真をアップロードするためのVant Uploaderコンポーネントを紹介し...
この記事の例では、要素のマウスドラッグ効果を実現するためのvue+tsの具体的なコードを参考までに共...
最近、WeChat アプレットを作成しているのですが、いくつか問題が発生しました。インターネットでい...