目次
コンストラクターで async/await を使用できません: 非同期オブジェクト構築の回避策
ホームページ ウェブフロントエンド jsチュートリアル JavaScript でオブジェクトの構築中に非同期操作を処理するにはどうすればよいですか?

JavaScript でオブジェクトの構築中に非同期操作を処理するにはどうすればよいですか?

Nov 28, 2024 am 02:09 AM

How Can I Handle Asynchronous Operations During Object Construction in JavaScript?

コンストラクターで async/await を使用できません: 非同期オブジェクト構築の回避策

問題: 内で async/await 構文を使用しようとしていますコンストラクター関数により、「クラス コンストラクターは非同期ではない可能性があります」というエラーが発生しますmethod."

原因: 非同期関数は Promise を返しますが、コンストラクターは構築中のオブジェクトを返します。これにより競合が発生し、async/await とコンストラクターの両方を同時に利用できなくなります。

回避策:

1.初期化関数 (init()):

  • クラス内に init() 関数を作成します。
  • コンストラクターは init() を呼び出します。これにより、非同期が可能になります。操作。
  • 使用法:

    1

    2

    3

    4

    var myObj = new myClass();

    myObj.init(function() {

      // Use myObj within the callback

    });

    ログイン後にコピー
  • 実装:

    1

    2

    3

    4

    5

    6

    7

    class myClass {

      constructor () {

      }

      init (callback) {

          // Asynchronous operations and callback

      }

    }

    ログイン後にコピー

2.ビルダー パターン:

  • コンストラクターは直接呼び出すとエラーをスローします。
  • 静的な build() メソッドは、 object.
  • 使用法:

    1

    2

    3

    4

    5

    6

    7

    myClass.build().then(function(myObj) {

      // Use myObj

    });

     

    async function foo () {

      var myObj = await myClass.build();

    }

    ログイン後にコピー
  • 実装:

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    class myClass {

      constructor (async_param) {

          if (async_param === undefined) {

              throw new Error('Cannot be called directly');

          }

      }

      static build () {

          return doSomeAsyncStuff()

                 .then(function(async_result){

                     return new myClass(async_result);

                 });

      }

      // Async/await equivalent:

      static async build () {

          var async_result = await doSomeAsyncStuff();

          return new myClass(async_result);

      }

    }

    ログイン後にコピー

注: ビルダーは代わりにコールバックを使用できます。 Promise.

静的関数内での関数の呼び出し:

  • 静的関数は (インスタンス メソッドとは異なり) オブジェクトにバインドされません。
  • したがって、これは、インスタンス化されたオブジェクトではなく、クラスを参照します。
  • To静的関数からインスタンス メソッドを呼び出し、通常の関数または静的メソッドのいずれかにします。

    1

    2

    3

    4

    5

    6

    7

    8

    class A {

      static foo () {

          bar1();   // OK

          A.bar2(); // OK

      }

      static bar2 () {}

    }

    function bar1 () {}

    ログイン後にコピー

以上がJavaScript でオブジェクトの構築中に非同期操作を処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

JavaScriptの文字列文字を交換します JavaScriptの文字列文字を交換します Mar 11, 2025 am 12:07 AM

JavaScriptの文字列文字を交換します

jQuery日付が有効かどうかを確認します jQuery日付が有効かどうかを確認します Mar 01, 2025 am 08:51 AM

jQuery日付が有効かどうかを確認します

jQueryは要素のパディング/マージンを取得します jQueryは要素のパディング/マージンを取得します Mar 01, 2025 am 08:53 AM

jQueryは要素のパディング/マージンを取得します

10 jQuery Accordionsタブ 10 jQuery Accordionsタブ Mar 01, 2025 am 01:34 AM

10 jQuery Accordionsタブ

10 jqueryプラグインをチェックする価値があります 10 jqueryプラグインをチェックする価値があります Mar 01, 2025 am 01:29 AM

10 jqueryプラグインをチェックする価値があります

ノードとHTTPコンソールを使用したHTTPデバッグ ノードとHTTPコンソールを使用したHTTPデバッグ Mar 01, 2025 am 01:37 AM

ノードとHTTPコンソールを使用したHTTPデバッグ

jQueryはscrollbarをdivに追加します jQueryはscrollbarをdivに追加します Mar 01, 2025 am 01:30 AM

jQueryはscrollbarをdivに追加します

カスタムGoogle検索APIセットアップチュートリアル カスタムGoogle検索APIセットアップチュートリアル Mar 04, 2025 am 01:06 AM

カスタムGoogle検索APIセットアップチュートリアル

See all articles