エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
【javascript基礎講座】クラスコンストラクタの内部で async/await を使う時の注意
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
【javascript基礎講座】クラスコンストラクタの内部で async/await を使う時の注意
開く/閉じる class HogeClass { async constructor(hoge) { // Promiseを返すなんらかのメソッド this.h... 開く/閉じる class HogeClass { async constructor(hoge) { // Promiseを返すなんらかのメソッド this.hogeContent = await initHogeAsync(hoge); } } //... const hogeInstance = new HogeClass('hoge'); // Error! このソースコードは通常ビルドエラーとなるか、仮にコンパイルを通過してしてしまったとしても内部エラーで停まります。 これはJavascriptのコンストラクタは通常実体のあるオブジェクトを返す関数である必要があるためです。 一方でasyncが修飾される場合にはPromiseインターフェイスを返す関数になり、呼び出した時点では中身の無い値へのプロキシです。 この場合、コンストラクタはasyncをつけることが本質的にできない訳です。