Monday, 5 February 2018

javascript - What do these three dots in React do?




What does the ... do in this React (using JSX) code and what is it called?





Answer



That's property spread notation. It was added in ES2018 (spread for arrays/iterables was earlier, ES2015), but it's been supported in React projects for along time via transpilation (as "JSX spread attributes" even though you could do it elsewhere, too, not just attributes).



{...this.props} spreads out the "own" enumerable properties in props as discrete properties on the Modal element you're creating. For instance, if this.props contained a: 1 and b: 2, then







would be the same as






But it's dynamic, so whatever "own" properties are in props are included.



Since children is an "own" property in props, spread will include it. So if the component where this appears had child elements, they'll be passed on to Modal. Putting child elements between the opening tag and closing tags is just syntactic sugar — the good kind — for putting a children property in the opening tag. Example:






class Example extends React.Component {
render() {
const { className, children } = this.props;
return (

{children}


);
}
}
ReactDOM.render(
[

Child in first
,
Child in second} />
],

document.getElementById("root")
);

.first {
color: green;
}
.second {
color: blue;
}










Spread notation is handy not only for that use case, but for creating a new object with most (or all) of the properties of an existing object — which comes up a lot when you're updating state, since you can't modify state directly:



this.setState(prevState => {
return {foo: {...prevState.foo, a: "updated"}};

});


That replaces this.state.foo with a new object with all the same properties as foo except the a property, which becomes "updated":





const obj = {
foo: {
a: 1,

b: 2,
c: 3
}
};
console.log("original", obj.foo);
// Creates a NEW object and assigns it to `obj.foo`
obj.foo = {...obj.foo, a: "updated"};
console.log("updated", obj.foo);

.as-console-wrapper {
max-height: 100% !important;

}




No comments:

Post a Comment

casting - Why wasn't Tobey Maguire in The Amazing Spider-Man? - Movies & TV

In the Spider-Man franchise, Tobey Maguire is an outstanding performer as a Spider-Man and also reprised his role in the sequels Spider-Man...