Benchmark.js v2.1.4
Eine robuste Benchmarking-Bibliothek, die hochauflösende Timer unterstützt und statistisch signifikante Ergebnisse liefert. Wie auf jsPerf zu sehen .
Dokumentation
Herunterladen
Installation
Die einzige harte Abhängigkeit von Benchmark.js ist lodash . Schließen Sie platform.js ein, um Benchmark.platform zu füllen .
In einem Browser:
1
2
3<script src="lodash.js"></script>
<script src="platform.js"></script>
<script src="benchmark.js"></script>
In einem AMD-Loader:
1
2
3
4
5
6
7
8require({
'paths': {
'benchmark': 'path/to/benchmark',
'lodash': 'path/to/lodash',
'platform': 'path/to/platform'
}
},
['benchmark'], function(Benchmark) {/*…*/});
Mit npm:
1$ npm i --save benchmark
In Node.js:
1var Benchmark = require('benchmark');
Nutzen Sie optional das Microtime-Modul von Wade Simmons:
1npm i --save microtime
Anwendungsbeispiel:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23var suite = new Benchmark.Suite;
// add tests
suite.add('RegExp#test', function() {
/o/.test('Hello World!');
})
.add('String#indexOf', function() {
'Hello World!'.indexOf('o') > -1;
})
// add listeners
.on('cycle', function(event) {
console.log(String(event.target));
})
.on('complete', function() {
console.log('Fastest is ' + this.filter('fastest').map('name'));
})
// run async
.run({ 'async': true });
// logs:
// => RegExp#test x 4,161,532 +-0.99% (59 cycles)
// => String#indexOf x 6,139,623 +-1.00% (131 cycles)
// => Fastest is String#indexOf
Unterstützung
Getestet in Chrome 54–55, Firefox 49–50, IE 11, Edge 14, Safari 9–10, Node.js 6–7 und PhantomJS 2.1.1.
BestieJS
Benchmark.js ist Teil der „Best in Class“ -Modulsammlung von BestieJS. Das bedeutet, dass wir solide Browser-/Umgebungsunterstützung, ES5+-Präzedenzfälle, Unit-Tests und jede Menge Dokumentation fördern.