--- title: Symbol.asyncIterator slug: Web/JavaScript/Reference/Global_Objects/Symbol/asyncIterator translation_of: Web/JavaScript/Reference/Global_Objects/Symbol/asyncIterator ---
Symbol.asyncIterator
符号指定了一个对象的默认异步迭代器。如果一个对象设置了这个属性,它就是异步可迭代对象,可用于for await...of
循环。
Symbol.asyncIterator
是一个用于访问对象的@@asyncIterator
方法的内建符号。一个异步可迭代对象必须要有Symbol.asyncIterator
属性。
{{js_property_attributes(0,0,0)}}
你可以通过设置[Symbol.asyncIterator]
属性来自定义异步可迭代对象。
const myAsyncIterable = new Object(); myAsyncIterable[Symbol.asyncIterator] = async function*() { yield "hello"; yield "async"; yield "iteration!"; }; (async () => { for await (const x of myAsyncIterable) { console.log(x); // expected output: // "hello" // "async" // "iteration!" } })();
目前没有默认设定了[Symbol.asyncIterator]
属性的JavaScript内建的对象。不过,WHATWG(网页超文本应用技术工作小组)Streams会被设定为第一批异步可迭代对象,[Symbol.asyncIterator]
最近已在设计规范中落地。
标准 | 状态 | 注释 |
---|---|---|
{{SpecName('ES2018', '#sec-symbol.asynciterator', 'Symbol.asyncIterator')}} | {{Spec2('ES2018')}} |
{{compat("javascript.builtins.Symbol.asyncIterator")}}