Lets say I have this code:
const {x, y} = point;
Babel will turn this into:
var _point = point,
x = _point.x,
y = _point.y;
Which is fine, but what if point is undefined? Now I get an error:
"Cannot read property 'x' of undefined"
.
So how do I avoid this?
I want to do something like
const {x, y} = {} = point;
but that's a syntax error.
I can only see that this is an option:
const {x, y} = point || {};
Which babel transpiles to:
var _ref = point || {},
x = _ref.x,
y = _ref.y;
Here we're creating an object just to avoid an undefined error. This seems wasteful.
Is there some syntax I'm missing that would avoid this? Something that would transpile to something like this:
var x, y;
if (typeof point !== 'undefined') {
x = point.x;
y = point.y;
}
To handle undefined error in ES6 object destructuring, you can do something like following
const {x, y} = {...point};
console.log(x) // undefined
console.log(y) // undefined
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With