文章插图
遍历数组通常用for循环ES5的话也可以使用forEach,ES5具有遍历数组功能的还有map、filter、some、every、reduce、reduceRight等,只不过他们的返回结果不一样 。但是使用foreach遍历数组的话,使用break不能中断循环,使用return也不能返回到外层函数 。
Array.prototype.method=function(){console.log(this.length);}var myArray=[1,2,4,5,6,7]myArray.name="数组"for (var index in myArray) { console.log(myArray[index]);}for in遍历数组的毛病1.index索引为字符串型数字,不能直接进行几何运算
2.遍历顺序有可能不是按照实际数组的内部顺序
3.使用for in会遍历数组所有的可枚举属性,包括原型 。例如上栗的原型方法method和name属性
所以for in更适合遍历对象,不要使用for in遍历数组 。
那么除了使用for循环,如何更简单的正确的遍历数组达到我们的期望呢(即不遍历method和name),ES6中的for of更胜一筹.
Array.prototype.method=function(){console.log(this.length);}var myArray=[1,2,4,5,6,7]myArray.name="数组";for (var value of myArray) { console.log(value);}
推荐阅读
- 正山小种是什么味道呢?
- js中数组 slice 和 splice 的使用
- es6中Array.from和数组去重
- JavaScript都得知道这3个数组方法
- java数据结构及算法总结
- PHP删除数组中指定值的元素的方法
- JS数组去重的几种方式
- JS中轻松遍历对象属性的几种方式
- 如何比较两个PHP多维数组
- Hive 超赞的解析 Json 数组的函数