This feature is not Baseline because it does not work in some of the most widely-used browsers.
The Symbol.dispose static data property represents the well-known symbol Symbol.dispose. The using declaration looks up this symbol on the variable initializer for the method to call when the variable goes out of scope.
The well-known symbol Symbol.dispose.
Property attributes of Symbol.dispose
| |
|---|---|
| Writable | no |
| Enumerable | no |
| Configurable | no |
An object is disposable if it has the [Symbol.dispose]() method. The method is expected to have the following semantics:
This method should not return a promise, as promises returned by [Symbol.dispose]() are not awaited by await using. To declare async disposables, use Symbol.asyncDispose.
[Symbol.dispose] allows the creation of custom disposables. See the using reference for more information.
class Disposable {
constructor() {
this.disposed = false;
}
[Symbol.dispose]() {
this.disposed = true;
}
get isDisposed() {
return this.disposed;
}
}
const resource = new Disposable();
{
using resourceUsed = resource;
console.log(resource.isDisposed); // false
}
console.log(resource.isDisposed); // true
| Specification |
|---|
| ECMAScript Async Explicit Resource Management> # table-1> |
| Desktop | Mobile | Server | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | Bun | Deno | Node.js | |
dispose |
125 | 125 | 141 | 111 | No | 125 | 141 | 83 | No | 27.0 | 125 | No | 1.0.23 | 1.37 |
24.0.020.4.0–21.0.0Only available forfs and stream resources.18.18.0–19.0.0Only available forfs and stream resources. |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol/dispose