Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
reduce.concat() vs flat() vs concat + spread vs reduce + spread
Compare the new ES6 spread operator with the traditional concat() method
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.2.1 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
reduce + Array.prototype.concat
9699300.0 Ops/sec
Array.prototype.flat
6767328.5 Ops/sec
concat + spread
4047933.8 Ops/sec
reduce + spread
4629690.5 Ops/sec
Tests:
reduce + Array.prototype.concat
var params = [[ 1, 2 ], [ "hello", true, 7 ]]; var other = params.reduce((acc, val) => acc.concat(val), []);
Array.prototype.flat
var params = [[ 1, 2 ], [ "hello", true, 7 ]]; var other = params.flat();
concat + spread
var params = [[ 1, 2 ], [ "hello", true, 7 ]]; var other = [].concat(...params);
reduce + spread
var params = [[ 1, 2 ], [ "hello", true, 7 ]]; var other = params.reduce((acc, val) => { acc.push(...val); return acc; }, []);