js遍历for,forEach, for in,for of
ECMAScript5(es5)有三种for循环
简单for
for in
forEach
ECMAScript6(es6)新增
for of
简单for
for是循环的基础语法,也是最常用的循环结构。没有兼容性问题,效率上:for > forEach > map >for in
forEach
forEach由es5提出,属于数组的迭代方法
概述: 方法让数组的每一项都执行一次给定的函数。
语法: array.forEach(callback[currentValue,index,array,thisArg]);
参数:
currentValue:当前遍历项。
index:当前项目的下标
array:当前数组本身
thisArg:修改内部值的指向。
特点:
forEach 方法为数组中含有有效值的每一项执行一次 callback 函数,那些已删除(使用 delete 方法等情况)或者从未赋值的项将被跳过(不包括那些值为 undefined 或 null 的项)。
forEach 遍历的范围在第一次调用 callback 前就会确定。调用forEach 后添加到数组中的项不会被 callback 访问到。如果已经存在的值被改变,则传递给 callback 的值是 forEach 遍历到他们那一刻的值。已删除的项不会被遍历到。
优点:
foreach会跳过数组中的空位
相对for来说更语义化
缺点:
不能中断循环,也不支持 continue 和 break,只能通过 return 来控制循环,但是不能退出循环本身。
兼容性: 只支持IE9及以上
性能: forEach 的速度不如 for
for in
此循环有一个特殊的用途:可以枚举任何对象的命名属性。实际上它是为循环”enumerable“对象而设计的。
需要注意的是,for-in 循环遍历的是对象的属性,而不是数组的索引。由于对象的属性没有顺序,for in循环输出的输出的属性名也是不可预测的
性能:
由于每次迭代操作要搜索实例或原型属性, for-in 循环的每次迭代都会产生更多开销,因此执行速度比其他循环类型慢。在同样的循环迭代操作中,其它类型循环速度要比它快7倍之多。除非对数目不详的对象属性进行操作,否则我们不推荐使用for in 循环。
Array 的真相 Array 在 Javascript 中是一个对象, Array 的索引是属性名。事实上, Javascript 中的 “array” 有些误导性, Javascript 中的 Array 并不像大部分其他语言的数组。
首先, Javascript 中的 Array 在内存上并不连续,其次, Array 的索引并不是指偏移量。实际上, Array 的索引也不是 Number 类型,而是 String 类型的。
我们可以正确使用如 arr[0] 的写法的原因是语言可以自动将 Number 类型的 0 转换成 String 类型的 "0" 。
所以,在 Javascript 中从来就没有 Array 的索引,而只有类似 "0" 、 "1" 等等的属性。有趣的是,每个 Array 对象都有一个 length 的属性,导致其表现地更像其他语言的数组。
但为什么在遍历 Array 对象的时候没有输出 length 这一条属性呢?那是因为 for-in 只能遍历“可枚举的属性”, length 属于不可枚举属性,实际上, Array 对象还有许多其他不可枚举的属性。
es6的for of
for of是由es6提出的,目的是作为遍历所有数据结构的统一方法。
我们先来回顾一下此前js的遍历方法:
foreach是为便利数组而设计的,不能正确响应break、continue和return语句
for in被设计用来枚举对象的属性的,遍历对象的属性
for in用在数组上,除了遍历数组元素以外,还会遍历自定义属性,甚至原型链上的属性,另外,遍历顺序是随机的
那么for of 有什么不一样呢?
特点:
语法同for in一样简洁,但避开了for in的缺陷
能正确响应break、continue和return语句
跟for in不一样,数组的遍历器接口只返回具有数字索引的属性
for in读取的是对象的键名,for of读取的是键值
提供遍历所有数据结构的统一方法。for of不仅可以遍历数组,还可以遍历Set、Map结构,某些类似数组的对象(如:argument对象、DOM NodeList对象),Generator对象,以及字符串。
如:
let arr = ['a' ,'b', 'c', 'd'];
let itr = arr[Symbol.iterator]; arr.forEach(function(val, index, arr){
console.log(val); // a b c d
console.log(index); // 0 1 2 3
}); for(let i of itr){
console.log(i); // a b c d
} for(let i of arr){
console.log(i); // a b c d
} for(let i in arr){
console.log(i); // 0 1 2 3
}
只要具有Iterator接口的数据结构,都可以使用for of循环遍历它的成员。关于Iterator,如果还不清楚的可以先去了解一下,这里就不赘述了。这里需要注意一下,由于for of读取的是键值,如果想通过for of获取键名,可以借助数组实例的entries和keys方法。
js遍历for,forEach, for in,for of的更多相关文章
- js遍历
最近看了一些不错的文章关于js遍历+js数组去重+文件上传的,今天也自己动手试了试.有好多之前不是细节不是很了解.正好学习了. map函数也是 类似这样的对象还有函数的属性arguments对象,当然 ...
- JS 遍历JSON中每个key值
JS 遍历JSON中的每个key值,可以按键值对进行存储: var myVar = { typeA: { option1: "one", option2: "two&qu ...
- JS中的forEach、$.each、map方法推荐
下面小编就为大家带来一篇JS中的forEach.$.each.map方法推荐.小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 orEach是ECMA5中Array新方法中最 ...
- Js遍历数组总结
Js遍历数组总结 遍历数组的主要方法为for.forEach.map.for in.for of for var arr = [1,2,3,4,5]; var n = arr.length; // 直 ...
- js 遍历集合删除元素
js 遍历集合删除元素 /** * 有效的方式 - 改变下标,控制遍历 */ for (var i = 0; i < arr.length; i++) { if (...) { arr.spli ...
- js遍历json对象
原生js遍历json对象 遍历json对象: 无规律: <script> var json = [ {dd:'SB',AA:'东东',re1:123}, {cccc:'dd',lk:'1q ...
- js遍历添加栏目类添加css 再点击其它删除css
//js遍历添加栏目类添加css 再点击其它删除css $(".radio-group .ckselect").each(function(index) { $(this).cli ...
- 用JS遍历循环时覆盖了之前的值
使用js遍历Echarts时,三个数据项,七个分类,遍历如下, 其他都没有问题,就是series.data里的数据只加载了一组,控制台显示数组的长度是7,可是下面的数据只有一个 发现把给数据项赋值的语 ...
- Freemarker的页面和JS遍历后台传入的Map
后端传到前端的Map Freemarker页面遍历Map: JS遍历Map:
随机推荐
- PAT 组合数的和(15)
给定N个非0的个位数字,用其中任意2个数字都可以组合成1个2位的数字.要求所有可能组合出来的2位数字的和.例如给定2.5.8,则可以组合出:25.28.52.58.82.85,它们的和为330. 输入 ...
- Django在不启动server的情况下调用方法
from django.conf import settingsfrom django import template settings.configure() a = template.Templa ...
- linux c编程:信号(四) sigaction
signal 函数的使用方法简单,但并不属于 POSIX 标准,在各类 UNIX 平台上的实现不尽相同,因此其用途受到了一定的限制.而 POSIX 标准定义的信号处理接口是 sigaction 函数, ...
- android 中使用svg
http://www.see-source.com/blog/300000038/1189.html http://www.jianshu.com/p/30dfa5920658#
- 上传项目至GitHub
在windows系统客户端安装git工具. 注:如何安装git工具在此不做介绍,如需了解可网上搜索安装介绍. 在“本地文件”中添加“.git文件”,用于git管理. 进入本地文件夹,右击鼠标- ...
- hive查询注意及优化tips
Hive是将符合SQL语法的字符串解析生成可以在Hadoop上执行的MapReduce的工具.使用Hive尽量按照分布式计算的一些特点来设计sql,和传统关系型数据库有区别, 所以需要去掉原有关系型数 ...
- Hadoop2.x + eclipse 插件配置
http://blog.csdn.net/u012874209/article/details/52105304 搭建集群那些就不用说了,主要有几个关键的地方需要注意(自己的Hadoop版本是2.5. ...
- Spark Mllib源码分析
1. Param Spark ML使用一个自定义的Map(ParmaMap类型),其实该类内部使用了mutable.Map容器来存储数据. 如下所示其定义: Class ParamMap privat ...
- Render树、RenderObject与RenderLayer
Chapter: 呈现树的构建 1. 呈现树与CSS盒子模型千丝万缕的关系 2. 呈现树与DOM树的关系 3. 浏览器构建呈现树的流程 4. Firefox的规则树和样式上下文树 5. 规则树是如何解 ...
- js 数组的所有操作
js的数组操作有很多,这里记录了常用的和不常用的数组操作方法. 一.数组的创建 数组的创建有两种方法,一种是通过字面量,另一种是通过Array构造函数. 1.字面量 var num1 = [1,2,3 ...