Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
JavaScript spread operator vs Object.assign performance vs merge mutation
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/17.4 Safari/605.1.15
Browser:
Safari 17
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
2 years ago
Test name
Executions per second
Using the spread operator
7531426.5 Ops/sec
Using Object.assign
7256352.0 Ops/sec
MergeObjects function
24928908.0 Ops/sec
Tests:
Using the spread operator
const firstObject = { sampleData: 'Hello world' } const secondObject = { moreData: 'foo bar' } const finalObject = { ...firstObject, ...secondObject };
Using Object.assign
const firstObject = { sampleData: 'Hello world' } const secondObject = { moreData: 'foo bar' } const finalObject = Object.assign(firstObject, secondObject);
MergeObjects function
function mergeObjects(target, source) { for (const key in source) { if (typeof source[key] === 'object' && source[key] !== null) { if (!target[key] || typeof target[key] !== 'object' || target[key] === null) { target[key] = {}; } mergeObjects(target[key], source[key]); } else { target[key] = source[key]; } } } const firstObject = { sampleData: 'Hello world' } const secondObject = { moreData: 'foo bar' } mergeObjects(firstObject, secondObject)