jquery里面有个each方法,将循环操做简化、便捷。
随后es出了个forEach方法,两个虽然用法相近,可是不能处理对象类型。且没法经过return true达到continue效果。
此外还有个every方法,该方法虽然能够实现continue效果,可是在处理类数组与对象类型时,彻底无用。
在不使用jquery
的each
方法时,该如何处理;或者说用原生如何来实现?
前些前写了个类库: jTool, 其中就实现了该方法。javascript
// 经过字面量方式实现的函数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; } })(); // 为数组或类数组时, 返回: index, value if(type === 'Array' || type === 'NodeList'){ // 因为存在类数组NodeList, 因此不能直接调用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; } } } }
var _array = [1,2,3,4]; each(_array, function(i, v){ console.log(i + ': ' + v); });
输出以下:前端
var object = {a:1, b:2, c:3}
each(object, function(i, v){
console.log(i + ': ' + v);
});
输出以下:java
var ele = document.querySelectorAll('div'); each(ele, function(i, v){ console.log(i + ': ' + v); });
输出以下:jquery
var object2 = {name:'baukh', age: '29', six:'男', url: 'www.lovejavascript.com',} each(object2, function(i, v){ if(i === 'age'){ //若是存在键值为age的属性时,则输出警告,用于实现continue效果 console.log('存在键值为age,这家伙已经'+v+'岁了'); return true; } if(i === 'six' && v === '男'){//若是存在键值为age的属性时,则输出跳出,用于实现break效果 console.log('存在键值为six,是个男的,不用关注了~'); return false; } console.log(i + ': ' + v); });
输出以下:git
从结果能够看出来,each方法已经实现了jquery的each功能。且实现如此简单~github
随笔一行
这是前端最好的时代, 这也是前端最坏的时代。 众多前端框架满天飞,随着 jQuery 在前端行业的慢慢弱化,老是会有一种斯人远去,何者慰籍的感受。互勉吧,各位。数组
另推荐个表格组件gridManager前端框架