ES6:迭代器和for-of循环

es6之前的循环

传统的循环

var myArray = [0, 1, 2, 3];
for (var index = 0; index < myArray.length; index++) {
  console.log(myArray[index]);
}

打印结果:

0
1
2
3

ES5支持的forEach()

var myArray = [0, 1, 2, 3];
myArray.forEach(function (value) {
  console.log(value);
});

打印结果:

0
1
2
3

这段代码看起来更加简洁,但这种方法也有一个小缺陷:你不能使用break语句中断循环,也不能使用return语句返回到外层函数。

for-in循环

var myArray = [0, 1, 2, 3];
for (var index in myArray) { // 千万别这样做
  console.log(myArray[index]);
}

打印结果:

0
1
2
3
  • 在这段代码中,赋给index的值是字符串“0”、“1”、“2”,而不是数字,稍不留意会导致字符串拼接而不是数字计算错误。
var myArray = [0, 1, 2, 3];
myArray.test = "test";
for (var index in myArray) { // 千万别这样做
  console.log(myArray[index]);
}

看上面这段代码,为myArray添加了一个属性test,执行结果如下:

0
1
2
3
test
  • for-in循环会遍历自定义属性。就连数组原型链上的属性都能被访问到。
  • 遍历的顺序不能保证。

强调一下:for-in是为普通对象设计的,你可以遍历普通对象的属性,键都是字符串,不适用于数组遍历。

ES6的for-of循环

        var myArray = [0, 1, 2, 3];
        for (var value of myArray) {
            console.log(value);
        }

打印结果:

0
1
2
3

for-of:

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

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

for-of循环可以遍历Map,Set,字符串等对象

for-of字符串遍历

它将字符串视为一系列的Unicode字符来进行遍历:

        var str = '测试代码';
        for (var chr of str) {
            console.log(chr);
        }

结果:

测
试
代
码

for-of Set遍历

        var mySet = new Set();
        mySet.add('test1');
        mySet.add('test2');

        for (var word of mySet) {
            console.log(word);
        }

结果:

test1
test2

for-of Map遍历

  test8(){

        var myMap = new Map();
        myMap.set('key1', 'value1');
        myMap.set('key2', 'value2');

        for (var [key, value] of myMap){
            console.log(key + ':'  + value);
        }

    }

结果:

key1:value1
key2:value2

解构(destructuring)

内建的Object.keys()

  test9(){
        var myObj = {
          key1: 'value1',
          key2: 'value2'
        };

        for (var key of Object.keys(myObj)){
            console.log(key);
        }

    }

结果:

key1
key2

迭代器

for-of循环语句通过方法调用来遍历各种集合。数组、Maps对象、Sets对象以及其它在我们讨论的对象有一个共同点,它们都有一个迭代器方法。

只要实现了迭代器的对象都可以使用for-of进行迭代,任何对象都可以实现自己的迭代器。

TODO 迭代器

参考

ES6 In Depth: Iterators and the for-of loop

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,440评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,814评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,427评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,710评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,625评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,014评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,511评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,162评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,311评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,262评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,278评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,989评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,583评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,664评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,904评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,274评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,856评论 2 339

推荐阅读更多精彩内容