首页 > 开发 > JS > 正文

原生js实现each方法实例代码详解

2024-05-06 16:51:29
字体:
来源:转载
供稿:网友

jquery里面有个each方法,将循环操作简化、便捷。 随后es出了个forEach方法,两个虽然用法相近,但是不能处理对象类型。且无法通过return true达到continue效果。 此外还有个every方法,该方法虽然可以实现continue效果,但是在处理类数组与对象类型时,完全无用。

在不使用 jquery 的 each 方法时,该如何处理;或者说用原生如何来实现? 前些前写了个类库: jTool , 其中就实现了该方法。

简单实现:

js;" style="margin: 3px auto 0px; padding: 0px 0px 0px 5px; outline: none; background-image: initial; background-position: initial; background-size: initial; background-repeat: initial; background-attachment: initial; background-origin: initial; background-clip: initial; width: 640px; line-height: 20px; clear: both; border-left: 3px solid rgb(108, 226, 108);">// 通过字面量方式实现的函数eachvar 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;   }  } }}

我们来try一下, 测试下数组、对象、类数组类型及中断效果

数组类型

var _array = [1,2,3,4];each(_array, function(i, v){ console.log(i + ': ' + v);});

输出如下:

js,each,代码

对象类型

var object = {a:1, b:2, c:3} each(object, function(i, v){ console.log(i + ': ' + v); });

输出如下:

js,each,代码

类数组类型

var ele = document.querySelectorAll('div');each(ele, function(i, v){ console.log(i + ': ' + v);});

输出如下:

js,each,代码

增加中断条件

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);});

输出如下:

js,each,代码

从结果可以看出来,each方法已经实现了jquery的each功能。且实现如此简单~

随笔一行 这是前端最好的时代, 这也是前端最坏的时代。 众多前端框架满天飞,随着 jQuery 在前端行业的慢慢弱化,总是会有一种斯人远去,何者慰籍的感觉。互勉吧,各位。

另推荐个表格组件 gridManager 

总结

以上所述是小编给大家介绍的原生js实现each方法实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对VeVb武林网网站的支持!


注:相关教程知识阅读请移步到JavaScript/Ajax教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表