@babel/plugin-proposal-object-rest-spread
Spread Properties
let n = { x, y, ...z };
console.log(n); // { x: 1, y: 2, a: 3, b: 4 }
npm install --save-dev @babel/plugin-proposal-object-rest-spread
Via CLI
babel --plugins @babel/plugin-proposal-object-rest-spread script.js
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-proposal-object-rest-spread"],
});
By default, this plugin will produce spec compliant code by using Babel’s objectSpread
helper.
boolean
, defaults to false
.
Enabling this option will use Babel’s extends
helper, which is basically the same as Object.assign
(see useBuiltIns
below to use it directly).
Please keep in mind that even if they’re almost equivalent, there’s an important difference between spread and Object.assign
: spread defines new properties, while Object.assign()
sets them, so using this mode might produce unexpected results in some cases.
For detailed information please check out Spread VS. Object.assign and .
boolean
, defaults to false
.
Example
.babelrc
{
"setSpreadProperties": true
},
"plugins": [
["@babel/plugin-proposal-object-rest-spread", { "useBuiltIns": true }]
]
}
In
z = { x, ...y };
Out