普通for循环写着麻烦,但是是性能最好
foreach循环,简洁,但是性能不及for
所以封装一下for循环,既简洁又高性能
自封装版forEach
function enhanceFor(obj, func) {
for (let i = obj.length - 1; i > -1; i--) {
func(obj[i], i);
}
}
添加到原型连上
Array.prototype.for=function(iteration){
for (let i = this.length - 1 ; i > -1; i--) {
if (iteration(this[i], i) === false) return;
}
}
Number.prototype.for=function(iteration){
for(let i=this-1;i>-1;i--){
if (iteration(i) === false) return;
}
}
性能测试
const testArray = [];
for (i = 1000000; i > 0; i--) {
testArray.push(Math.random())
}
let count = 0;
count = 0;
console.time('superFor')
// testArray.forEach(item => {
// if (testArray[i] > 0.2) count++;
// })
enhanceFor(testArray,item=>{
if(item>0.2)count++;
})
console.timeEnd('superFor')
console.time('changgui常规循环')
for (let i = testArray.length - 1; i > -1; i--) {
if (testArray[i] > 0.2) count++;
}
console.timeEnd('changgui常规循环');
console.log(count)
count = 0;
console.time('foreach')
testArray.forEach(item => {
if (item > 0.2) count++;
})
console.timeEnd('foreach')
console.log(count)