JavaScript の非同期関数はどのようにして常に Promise を返すのでしょうか?
非同期関数と Promise の関係を理解する
JavaScript では、非同期関数を使用すると、同期しているように見えるコードを作成できるため、非同期プログラミングが簡素化されます。非同期で実行されます。ただし、非同期関数が Promise とどのように相互作用するかを理解することは非常に重要です。
問題
次の非同期関数について考えてみましょう。
async function latestTime() { const bl = await web3.eth.getBlock('latest'); console.log(bl.timestamp); // Returns a primitive console.log(typeof bl.timestamp.then == 'function'); // Returns false - not a promise return bl.timestamp; }
latestTime() を呼び出すと、web3.eth.getBlock からタイムスタンプのプリミティブ値を受け取ることが期待されるかもしれません。ただし、代わりに、次のように保留中の Promise が返されます。
const time = latestTime(); // Promise { <pending> }
Promise が返される理由
非同期関数は常に Promise を返します。この Promise は、関数が非同期操作を完了して最終値を提供するか、エラーで拒否されたときに解決されます。 latestTime() の場合、Promise はタイムスタンプ プリミティブで解決されます。
Promise の処理方法
別の非同期関数の外側で、解決された値にアクセスするか、任意の値を処理する約束の then メソッドエラー:
latestTime() .then(time => { console.log(time); }) .catch(error => { // Handle/report error });
トップレベルの await
最新の環境ではモジュールでトップレベルの await がサポートされており、次のようなコードを記述できます:
const time = await latestTime();
この構文により、モジュール レベルでの Promise の操作が簡素化されます。ただし、モジュール内で未処理の Promise 拒否が発生すると、モジュールのロードに失敗する可能性があることに注意してください。
Promises を使用した非同期関数について理解する
非同期関数がどのように連携して動作するかをよりよく理解するにはPromise を使用する場合、JavaScript エンジンが非同期関数を Promise Executor にコンパイルする方法を検討すると役立ちます。 function:
function latestTime() { return new Promise((resolve, reject) => { web3.eth.getBlock('latest') .then(bl => { console.log(bl.timestamp); console.log(typeof bl.timestamp.then == 'function'); resolve(bl.timestamp); }) .catch(reject); }); }
この表現:
- 非同期関数は、新しい Promise に渡される Promise Executor 関数として表されます。
- 非同期操作は次のときに開始されます。 web3.eth.getBlock は同期的に呼び出されます。
- Promiseコールバックは、Promise を解決または拒否するために使用されます。
結果として、非同期関数は呼び出し側コードに事実上 Promise を返します。
以上がJavaScript の非同期関数はどのようにして常に Promise を返すのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

フロントエンドのVSCodeと同様に、パネルドラッグアンドドロップ調整機能の実装を調べます。フロントエンド開発では、VSCODEと同様のVSCODEを実装する方法...
