文档章节

ES6 迭代器和for-of

前端小虾
 前端小虾
发布于 2017/09/08 14:09
字数 714
阅读 6
收藏 0

ECMscript定义了

1、语言规范 

2、数据类型

3、原型和继承

4、内建对象和函数的标准库

ECMScript标准不定义html或css相关的功能,也不定义类似dom的webAPI,这些都是在独立的标准中进行定义。

迭代器和for-of 循环

1、

for (var index = 0; index < myArray.length; index++) { console.log(myArray[index]);

}

2、myArray.forEach(function (value) { console.log(value);
});

,缺点:不能使用break语句中断循环,也不能使用return语句返回到外层函数。

3、for (var index in myArray) { // 千万别这样做 console.log(myArray[index]);

}

a、在这段代码中,赋给index的值不是实际的数字,而是字符串“0”、“1”、“2”,此时很可能在无 意之间进行字符串算数计算,例如:“2” + 1 == “21”,这给编码过程带来极大的不便。

b、作用于数组的for-in循环体除了遍历数组元素外,还会遍历 自定义属性。举个例子,如果你的数组中有 一个可枚举属性myArray.name,循环将额外执行一次,遍历到名为“name”的索引。就连数组原型 链上的属性都能被访问到。

c、最让人震惊的是,在某些情况下,这段代码可能按照随机顺序遍历数组元素。

d、简而言之,for-in是为普通对象设计的,你可以遍历得到字符串类型的键,因此不适用于数组遍历

4、强大的for-of循环  for(var value of myArray) { console.log(value);}

这是最简洁、最直接的遍历数组元素的语法 这个方法避开了for-in循环的所有缺陷 与forEach()不同的是,它可以正确响应break、continue和return语句

for-in循环用来遍历对象属性。 for-of循环用来遍历数据—例如数组中的值。 但是,不仅如此!

for-of循环也可以遍历其它的集合

for-of循环不仅支持数组,还支持大多数类数组对象,例如DOM NodeList对象。 for-of循环也支持字符串遍历,它将字符串视为一系列的Unicode字符来进行遍历:

for (var chr of "") { alert(chr);}

它同样支持Map和Set对象遍历

 

举个例子,Set对象可以自动排除重复项:

// 基于单词数组创建一个set对象
var uniqueWords = new Set(words);

生成Set对象后,你可以轻松遍历它所包含的内容:

for (var word of uniqueWords) { console.log(word);

}

现在,你只需记住:未来的JS可以使用一些新型的集合类,甚至会有更多的类型陆续诞生,而for-of就是 为遍历所有这些集合特别设计的循环语句。

for-of循环不支持普通对象,但如果你想迭代一个对象的属性,你可以用for-in循环(这也是它的本职工 作)或内建的Object.keys()方法:

 

 

 

© 著作权归作者所有

共有 人打赏支持
下一篇: state
前端小虾
粉丝 1
博文 44
码字总数 21084
作品 0
东城
私信 提问
ES6 系列之迭代器与 for of

起源 一段标准的 for 循环代码: 看着很简单,但是再回顾这段代码,实际上我们仅仅是需要数组中元素的值,但是却需要提前获取数组长度,声明索引变量等,尤其当多个循环嵌套的时候,更需要使...

冴羽
07/10
0
0
【探秘ES6】系列专栏(三):生成器

ES6作为新一代JavaScript标准,即将与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,Mozilla Web开发者博客推出了《ES6 In Depth》系列文章。CSDN已获授权,将持续对该系...

一配
2015/10/27
0
0
ES6 系列之模拟实现一个 Set 数据结构

基本介绍 ES6 提供了新的数据结构 Set。 它类似于数组,但是成员的值都是唯一的,没有重复的值。 初始化 Set 本身是一个构造函数,用来生成 Set 数据结构。 Set 函数可以接受一个数组(或者具...

冴羽
07/18
0
0
es6 新特性整理

本文没有详细描述这些新特性,因为网上都已经有很多相关的介绍了。主要针对ES6 新特性收集了相关范例代码,他可以让你快速了解这个新的javascript规范。 箭头函数 function() 函数的简写表示...

sinat_17775997
2017/12/17
0
0
【探秘ES6】系列专栏(二):迭代器和for-of循环

ES6作为新一代JavaScript标准,即将与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,Mozilla Web开发者博客推出了《ES6 In Depth》系列文章。CSDN已获授权,将持续对该系...

一配
2015/10/22
143
0

没有更多内容

加载失败,请刷新页面

加载更多

CompletableFuture get方法一直阻塞或抛出TimeoutException

问题描述 最近刚刚上线的服务突然抛出大量的TimeoutException,查询后发现是使用了CompletableFuture,并且在执行future.get(5, TimeUnit.SECONDS);时抛出了TimeoutException异常,导致接口响...

xiaolyuh
14分钟前
0
0
dubbo 搭建与使用

官网:http://dubbo.apache.org/en-us/ 一,安装监控中心(可以不安装) admin管理控制台,monitor监控中心 下载 bubbo ops 这个是新版的,需要node.js环境,我没有就用老版的了...

小兵胖胖
17分钟前
1
0
mac 下 mysql 8.0.13 安装并记录遇到的问题 以便以后查看

安装 官网mysql 下载地址 安装过程 省去 安装好之后 下载navicat 错误1 链接 遇到 mysql 2003 - Can't connect to MySQL server 错误, 解决方案 重启mysql 服务 #错误2 ERROR 1045: Acces...

杭州-IT攻城狮
昨天
5
0

中国龙-扬科
昨天
1
0
[Spring4.x]基于spring4.x纯注解的Web工程搭建

在前文中已经说明了如何基于 Spring4.x+ 版本开发纯注解的非web项目,链接如下: https://my.oschina.net/morpheusWB/blog/2985600 本文则主要说明,如何在Web项目中,"基于spring纯注解方式...

morpheusWB
昨天
18
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部