ES6新特性for...of(2018-05-22)

????for...of 一種用于遍歷數(shù)據(jù)結(jié)構(gòu)的方法。它可遍歷的對象包括數(shù)組灯帮,對象崖技,字符串,set和map結(jié)構(gòu)等具有iterator 接口的數(shù)據(jù)結(jié)構(gòu)钟哥。

傳統(tǒng)遍歷方式與for...of優(yōu)缺

1迎献、for 循環(huán)
var arr = [1,2,3,4,5];
    for(let i = 0;i<arr.length;i++){
        //...
    }
//缺點(diǎn):代碼不夠簡潔。
2腻贰、forEach
var arr = [1,2,3,4,5];
arr.forEach(function (value,index) {
   //...
});
//缺點(diǎn):無法中斷停止整個循環(huán)吁恍。
3、for...in
var arr = [1,2,3,4,5];
    for(let i in arr){
        //...
    } 

for...in循環(huán)更常用于對象的循環(huán),如果用于數(shù)組的循環(huán)冀瓦,那么就要注意了伴奥,上述代碼中每次循環(huán)中得到的i是字符串類型,而不是預(yù)料中的數(shù)字類型翼闽,要想對它進(jìn)行運(yùn)算拾徙,那得先要進(jìn)行類型轉(zhuǎn)換,造成不方便肄程。

4锣吼、for...of
var arr = [1,2,3,4,5];
for(let value of arr){
    console.log(value);
}
//打印結(jié)果:依次輸出:1 2 3 4 5

寫法比for循環(huán)簡潔很多;
可以用break來終止整個循環(huán)蓝厌,或者continute來跳出當(dāng)前循環(huán)玄叠,繼續(xù)后面的循環(huán);
結(jié)合keys( )獲取到循環(huán)的索引拓提,并且是數(shù)字類型读恃,而不是字符串類型。

循環(huán)可以終止

var arr = [1,2,3,4,5];
    for(let value of arr){
        if(value == 3){
            //終止整個循環(huán)
            break;
        }
        console.log(value);
    }
    //打印結(jié)果:1 2

用break實(shí)現(xiàn)了終止整個循環(huán)代态,不會繼續(xù)后面的遍歷寺惫,所以打印結(jié)果為:1 2。

可跳過當(dāng)前循環(huán)

var arr = [1,2,3,4,5];
    for(let value of arr){
        if(value == 3){
            //跳過當(dāng)前循環(huán)蹦疑,繼續(xù)后面的循環(huán)
            continue;
        }
        console.log(value);
    }
    //打印結(jié)果:1 2 4  5

用continue跳過當(dāng)前循環(huán)西雀,繼續(xù)后面的循環(huán),所以打印結(jié)果為:1 2 4 5歉摧。

得到數(shù)字類型的索引

var arr = [1,2,3,4,5];
    for(let index of arr.keys()){
        console.log(index);
    }
    //打印結(jié)果:依次輸出:0 1 2 3 4

遍歷字符串

let word = "我愛吃花生";
    for(let w of word){
        console.log(w);
    }
    //打印結(jié)果:我  愛  吃  花  生

遍歷DOM List

    <p>1</p>
    <p>2</p>
    <p>3</p>
    //假設(shè)有3個p元素
    let pList = document.getElementsByTagName('p');

    for(let p of pList){
        console.log(p);
    }
    // 打印結(jié)果:<p>1</p>
    //          <p>2</p>
    //          <p>3</p>

json數(shù)組循環(huán)

var arr1 = [{a:1},{a:2},{a:3}];
for (var val of arr1.keys()) { 
    console.log(val,arr1[val].a)
}
// 0 1
// 1 2
// 2 3

var arr1 = [{a:1},{a:2},{a:3}];
for (var val of arr1) { 
    console.log(val)
}
// 1
// 2
// 3

for of不能遍歷對象艇肴,因?yàn)槟軌虮籪or...of正常遍歷的,都需要實(shí)現(xiàn)一個遍歷器Iterator叁温。而數(shù)組再悼、字符串、Set膝但、Map結(jié)構(gòu)冲九,早就內(nèi)置好了Iterator(迭代器),它們的原型中都有一個Symbol.iterator方法跟束,而Object對象并沒有實(shí)現(xiàn)這個接口莺奸,使得它無法被for...of遍歷。例如:


Array.prototype[Symbol.iterator];
 
// ? values() { [native code] }
 
String.prototype[Symbol.iterator];
 
// ? [Symbol.iterator]() { [native code] }
 
Set.prototype[Symbol.iterator];
 
// ? values() { [native code] }
 
Map.prototype[Symbol.iterator];
 
// ? entries() { [native code] }
 
Object.prototype[Symbol.iterator];
 
// undefined
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末冀宴,一起剝皮案震驚了整個濱河市憾筏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌花鹅,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,430評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件枫浙,死亡現(xiàn)場離奇詭異刨肃,居然都是意外死亡古拴,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評論 3 398
  • 文/潘曉璐 我一進(jìn)店門真友,熙熙樓的掌柜王于貴愁眉苦臉地迎上來黄痪,“玉大人,你說我怎么就攤上這事盔然∥Υ颍” “怎么了?”我有些...
    開封第一講書人閱讀 167,834評論 0 360
  • 文/不壞的土叔 我叫張陵愈案,是天一觀的道長挺尾。 經(jīng)常有香客問我,道長站绪,這世上最難降的妖魔是什么遭铺? 我笑而不...
    開封第一講書人閱讀 59,543評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮恢准,結(jié)果婚禮上魂挂,老公的妹妹穿的比我還像新娘。我一直安慰自己馁筐,他們只是感情好涂召,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著敏沉,像睡著了一般果正。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上赦抖,一...
    開封第一講書人閱讀 52,196評論 1 308
  • 那天舱卡,我揣著相機(jī)與錄音,去河邊找鬼队萤。 笑死轮锥,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的要尔。 我是一名探鬼主播舍杜,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼赵辕!你這毒婦竟也來了既绩?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,671評論 0 276
  • 序言:老撾萬榮一對情侶失蹤还惠,失蹤者是張志新(化名)和其女友劉穎饲握,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,221評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡救欧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評論 3 340
  • 正文 我和宋清朗相戀三年衰粹,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片笆怠。...
    茶點(diǎn)故事閱讀 40,444評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡铝耻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蹬刷,到底是詐尸還是另有隱情瓢捉,我是刑警寧澤,帶...
    沈念sama閱讀 36,134評論 5 350
  • 正文 年R本政府宣布办成,位于F島的核電站泡态,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏诈火。R本人自食惡果不足惜兽赁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望冷守。 院中可真熱鬧刀崖,春花似錦、人聲如沸拍摇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽充活。三九已至蜂莉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間混卵,已是汗流浹背映穗。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留幕随,地道東北人蚁滋。 一個月前我還...
    沈念sama閱讀 48,837評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像赘淮,于是被迫代替她去往敵國和親辕录。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)梢卸,也就是一...
    悟名先生閱讀 4,151評論 0 13
  • Lua 5.1 參考手冊 by Roberto Ierusalimschy, Luiz Henrique de F...
    蘇黎九歌閱讀 13,831評論 0 38
  • 官網(wǎng) 中文版本 好的網(wǎng)站 Content-type: text/htmlBASH Section: User ...
    不排版閱讀 4,401評論 0 5
  • 一走诞、Java 簡介 Java是由Sun Microsystems公司于1995年5月推出的Java面向?qū)ο蟪绦蛟O(shè)計(jì)...
    子非魚_t_閱讀 4,202評論 1 44
  • 時光在走 我們?nèi)顼L(fēng) 親愛的親愛的 你在何方 執(zhí)著和自由是你的夢 風(fēng)兒把我給的祝福唱 舊年里的故事不敢忘 哪怕一滴記...
    大氣睿智閱讀 150評論 0 0