Iterator.prototype[Symbol.dispose]()
The [Symbol.dispose]()
method of {{jsxref("Iterator")}}
instances implements the disposable protocol and allows it to be disposed when used with {{jsxref("Statements/using", "using")}}
. It calls the return()
method of this
, if it exists.
Syntax
iterator[Symbol.dispose]()
Parameters
None.
Return value
None ({{jsxref("undefined")}}
).
Examples
Declaring an iterator with using
The Symbol.dispose
method is intended to be automatically called in a using
declaration. This is useful if you have an iterator that you manually iterate over by calling its next()
method; if you iterate it with {{jsxref("Statements/for...of", "for...of")}}
or something similar, then error handling and cleanup is done automatically.
function* generateNumbers() {
try {
yield 1;
yield 2;
yield 3;
} finally {
console.log("Cleaning up");
}
}
function doSomething() {
using numbers = generateNumbers();
const res1 = numbers.next();
// Not iterating the rest of the numbers
// Before the function exits, the async iterator is disposed
// Logs "Cleaning up"
}
doSomething();
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}
See also
- Polyfill of
Iterator.prototype[Symbol.dispose]
incore-js
- JavaScript resource management
{{jsxref("Symbol.dispose")}}
{{jsxref("Statements/using", "using")}}