Jquery里面有個each方法,將循環(huán)操作簡化、便捷。
隨后es出了個forEach方法,兩個雖然用法相近,但是不能處理對象類型。且無法通過return true達(dá)到continue效果。
此外還有個every方法,該方法雖然可以實現(xiàn)continue效果,但是在處理類數(shù)組與對象類型時,完全無用。
在不使用jquery的each方法時,該如何處理;或者說用原生如何來實現(xiàn)?我在GridManager.js中集成了該方法,代碼如下:
// 通過字面量方式實現(xiàn)的函數(shù)each
var each = function(object, callback){
var type = (function(){
switch (object.constructor){
case Object:
return 'Object';
break;
case Array:
return 'Array';
break;
case NodeList:
return 'NodeList';
break;
default:
return 'null';
break;
}
})();
// 為數(shù)組或類數(shù)組時, 返回: index, value
if(type === 'Array' || type === 'NodeList'){
// 由于存在類數(shù)組NodeList, 所以不能直接調(diào)用every方法
[].every.call(object, function(v, i){
return callback.call(v, i, v) === false ? false : true;
});
}
// 為對象格式時,返回:key, value
else if(type === 'Object'){
for(var i in object){
if(callback.call(object[i], i, object[i]) === false){
break;
}
}
}
}
我們來try一下, 測試下數(shù)組、對象、類數(shù)組類型及中斷效果
數(shù)組類型:
var _array = [1,2,3,4];
each(_array, function(i, v){
console.log(i + ': ' + v);
});
輸出如下:
1479818070754.png
對象類型:
var object = {a:1, b:2, c:3}
each(object, function(i, v){
console.log(i + ': ' + v);
});
輸出如下:
類數(shù)組類型 :
var ele = document.querySelectorAll('div');
each(ele, function(i, v){
console.log(i + ': ' + v);
});
輸出如下:
增加中斷條件:
var object2 = {name:'baukh', age: '29', six:'男', url: 'www.lovejavascript.com',}
each(object2, function(i, v){
if(i === 'age'){ //如果存在鍵值為age的屬性時,則輸出警告,用于實現(xiàn)continue效果
console.log('存在鍵值為age,這家伙已經(jīng)'+v+'歲了');
return true;
}
if(i === 'sex' && v === '男'){//如果存在鍵值為age的屬性時,則輸出跳出,用于實現(xiàn)break效果
console.log('存在鍵值為sex,是個男的,不用關(guān)注了~');
return false;
}
console.log(i + ': ' + v);
});
輸出如下:
從結(jié)果可以看出來,each方法已經(jīng)實現(xiàn)了jquery的each功能。且實現(xiàn)如此簡單~
@拭目以待
個人站點(diǎn):www.lovejavascript.com
表格管理插件:gridmanager.lovejavascript.com && github地址
QQ交流群 (452781895):How To Make Love
《野生前端工程師》專輯中所有文章均為@拭目以待 原創(chuàng),轉(zhuǎn)載請注明出處。