Optional assignment operator
Darien Valentine
valentinium at gmail.com
Thu Jul 5 00:16:47 UTC 2018
> My thought was to have the following: this.foo ?= params?.foo; which can
be desugared to if (($ref = params?.foo) !== undefined) { this.foo = $ref; }
Are there any specific advantages to the new syntax you’re describing?
Initially, it appears to me like a less powerful form of an existing
syntactic feature — default initializers and binding patterns allow
expressing the same logic:
```
const obj = {
demo(params={}) {
({ foo: this.foo=this.foo } = params);
console.log(
`params was ${ JSON.stringify(params) }; ` +
`this.foo is now ${ JSON.stringify(this.foo) }`
);
}
}
obj.demo({ foo: 1 });
obj.demo({})
obj.demo({ foo: 2 });
obj.demo();
obj.demo({ foo: 3 });
obj.demo({});
```
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.mozilla.org/pipermail/es-discuss/attachments/20180704/80b6a6cc/attachment-0001.html>
More information about the es-discuss
mailing list