tc39 / proposal-optional-catch-binding

proposal for ECMAScript to allow omission of the catch binding

Home Page:https://tc39.github.io/proposal-optional-catch-binding/

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

This proposal makes a grammatical change to ECMAScript, allowing the omission of a catch binding in cases where the binding would not be used. This occurs frequently with patterns such as

try {
  // try to use a web feature which may not be implemented
} catch (unused) {
  // fall back to a less desirable web feature with broader support
}

or

let isTheFeatureImplemented = false;
try {
  // stress the required bits of the web API
  isTheFeatureImplemented = true;
} catch (unused) {}

or

let parseResult = someFallbackValue;
try {
  parseResult = JSON.parse(potentiallyMalformedJSON);
} catch (unused) {}

and it is a common opinion that variables which are declared or written to but never read signify a programming error.

The grammar change introduced by this proposal allows for the catch binding and its surrounding parentheses to be omitted, as in

try {
  // ...
} catch {
  // ...
}

See the the full text of the proposal for more info.

About

proposal for ECMAScript to allow omission of the catch binding

https://tc39.github.io/proposal-optional-catch-binding/


Languages

Language:HTML 75.0%Language:Shell 23.3%Language:Makefile 1.7%