文档章节

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】系列专栏(三):生成器

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

一配
2015/10/27
0
0
【探秘ES6】系列专栏(二):迭代器和for-of循环

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

一配
2015/10/22
143
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 对象是伪数组 两个事实 ...

边城__
08/15
0
0

没有更多内容

加载失败,请刷新页面

加载更多

django rest framework 外键序列化方法与问题总结

django rest framework 外键序列化方法与问题总结 当借口中需要出现一对多关系的时候,我们可以用rest_framwork的序列化功能来处理,代码如下. # models.pyfrom django.db import modelscl...

_Change_
昨天
0
0
SingleNumber136 leetCode

Given a non-empty array of integers, every element appears twice except for one. Find that single one. Note: Your algorithm should have a linear runtime complexity. Could you im......

woshixin
昨天
1
0
String ,  StringBuffer ,  StringBuilder的区别

String , StringBuffer , StringBuilder的区别 String 首先,String 是用来表示一个字符串常量的,它是一个不可变对象,意味着,一旦我们创建了某个字符串之后,就不能再改变它的值了,我们可...

tsmyk0715
昨天
3
0
区块链100讲:UTXO 和 Account 模型对比

在当前区块链世界中,主要有两种记录保存方式,UTXO 模式(Unspent Transaction Output) 和 Account 模式。Bitcoin 采用的是 UTXO 模型,Ethereum 采用的 Account 模型,同样 CITA 也采用了 ...

HiBlock
昨天
1
0
Vue中路由管理器Vue Router使用介绍(三)

一、路由定义添加动态参数定义 1.路由定义项,使用:xx 方式 定义动态参数 { path:'/user/:id/:name', name:'user', component:()=>import('./views/User.vue') ...

tianma3798
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部