文档章节

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()方法:

 

 

 

© 著作权归作者所有

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

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

冴羽
07/10
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
【探秘ES6】系列专栏(三):生成器

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

一配
2015/10/27
0
0
ES6 的 for..of 和 Generator,从伪数组 jQuery 对象说起

pseudo 英 ['sju:dəʊ] 美 ['su:doʊ] adj.假的,虚伪的 n.[口]假冒的人,伪君子 pseudo-array 英 [s'ju:dəʊər'eɪ] 美 [s'ju:dəʊər'eɪ] [计] 伪数组 jQuery 对象是伪数组 两个事实 ...

边城__
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

git +STS使用问题解决一

1. 2.点以一个pull就是更新代码 3.synchronize workSpace 同步代码,同SVN一致

森火
7分钟前
0
0
powerBi odbc 连接impala 实现自助分析

配置Impala以使用ODBC 可以将第三方产品设计为使用ODBC与Impala集成。为获得最佳体验,请确保支持您打算使用的任何第三方产品。验证支持包括检查Impala,ODBC,操作系统和第三方产品的版本是...

hblt-j
12分钟前
0
0
Purism FAQ

<font size="37" color="#006248" face="幼圆"> <p align="center"> Purism FAQ </p> </font> 原文:https://puri.sm/faq/ 原作者:Purism Team 翻译者:冰焰火灵X 1079092922@qq.com 文章许......

ICE冰焰火灵X
27分钟前
0
0
nginx+webdav

1、配置Nginx以支持WebDav: Webdav是nginx一个组件,默认编译nginx时是没有安装这个组件的。 如果跟应用公用一个nginx,需要重新编译安装nginx,重新安装前需要备份好原来的nginx.conf。 1....

yaukie
33分钟前
0
0
spring 事件

ContextRefreshedEvent Event raised when an {@code ApplicationContext} gets initialized or refreshed. ContextClosedEvent Event raised when an {@code ApplicationContext} gets clos......

Canaan_
44分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部