×
ECMAScript
標準組込オブジェク
ト
標準組込コンストラクター
非公開オブジェクト
インターフェース
【JSリファレンス】AsyncIterableインターフェース
更新日:2024/06/14
AsyncIterableインターフェースは、オブジェクトを非同期のイテラブルなオブジェクトとして動作させるために必要なプロパティ定義です。
プロパティ名 | 値の型 | 内容 |
---|---|---|
Symbol.asyncIterator | AsyncIteratorインターフェース を実装したオブジェクト を返す関数 | 関数により返された 非同期イテレーター により反復処理が 行われる |
■使用例
// 500ミリ秒待機するPromise
const sleep500 = (done,value)=> new Promise(
resolve =>setTimeout(
()=>resolve({
done:done,
value:`500ミリ秒待機しました(${value})`
})
, 500 )
);
// 非同期イテレーターを返す関数
const asyncIterator = function(){
const data = this.data.reverse();
return {
next:function(){
return data.length ? sleep500( false , data.pop() )
: sleep500( true );
}
}
}
// 非同期イテラブルなオブジェクト
const obj = {
data:[1,2,3],
[Symbol.asyncIterator]:asyncIterator
};
(async ()=>{
// 値を列挙
for await( const value of obj ){
console.log( value );
}
})();
// 結果:
// 500ミリ秒待機しました(1)
// 500ミリ秒待機しました(2)
// 500ミリ秒待機しました(3)
更新日:2024/06/14
スポンサーリンク
記事の内容について

こんにちはけーちゃんです。
説明するのって難しいですね。
「なんか言ってることおかしくない?」
たぶん、こんなご意見あると思います。
裏付けを取りながら記事を作成していますが、僕の勘違いだったり、そもそも情報源の内容が間違えていたりで、正確でないことが多いと思います。
そんなときは、ご意見もらえたら嬉しいです。
掲載コードについては事前に動作確認をしていますが、貼り付け後に体裁を整えるなどをした結果動作しないものになっていることがあります。
生暖かい視線でスルーするか、ご指摘ください。
ご意見、ご指摘はこちら。
https://jsref.affi-sapo-sv.com/info.php
このサイトは、リンクフリーです。大歓迎です。