js遍歷循環(huán)for/for...in/for...of/forEach()/map()

【1】for循環(huán)

for (語句 1; 語句 2; 語句 3)
{
  //被執(zhí)行的代碼塊
}

語句 1 在循環(huán)(代碼塊)開始前執(zhí)行
語句 2 定義運行循環(huán)(代碼塊)的條件
語句 3 在循環(huán)(代碼塊)已被執(zhí)行之后執(zhí)行

//實例:
for(var i=0;i<li.length;i++){
// do something
}

【2】for...in循環(huán)遍歷

var arr=["a","b","c"]
arr.name="wayne"
for(let i in arr){
  console.log(arr[i])
}
image.png

(1)for..in實際遍歷的是對象的屬性拣播,當(dāng)循環(huán)遍歷的目標(biāo)是數(shù)組時則被他當(dāng)成一個對象,每個數(shù)組元素的索引被視為一個屬性0:a,1:b,2:c,name:wayne;所以abc和wayne都被遍歷出來了(但不包括Array的length屬性)
(2)for...in 其中i是索引數(shù)組下標(biāo)
(3)既可以遍歷數(shù)組又可以遍歷對象

【3】for...of循環(huán)遍歷

var arr=["a","b","c"]
arr.name="wayne"
for(let i of arr){
  console.log(i)
}
image.png

(1)for … of循環(huán)則修復(fù)for...in的一些問題拯刁,它只循環(huán)集合本身的元素,所以只輸出abc不輸出wayne
(2)for...of是es6出來的逝段,只用于遍歷數(shù)組垛玻,其中i是元素;
(3)for...of 不可以遍歷對象奶躯,會報錯,因為能夠被for...of正常遍歷的帚桩,都需要實現(xiàn)一個遍歷器Iterator。而數(shù)組嘹黔、字符串朗儒、Set、Map結(jié)構(gòu)参淹,早就內(nèi)置好了Iterator(迭代器)醉锄,它們的原型中都有一個Symbol.iterator方法,而Object對象并沒有實現(xiàn)這個接口浙值,使得它無法被for...of遍歷恳不。

image.png

指路:特殊處理下for...of也可遍歷對象

【4】原生Js forEach()循環(huán)遍歷

var arr=["a","b","c"]
arr.name="wayne"
arr.forEach(function(item,index,arr){ 
    console.log(item)
})

//箭頭函數(shù)
arr.forEach((item,index,arr)=>{  
    console.log(item);  
});
image.png

【5】原生Js map()循環(huán)遍歷

var arr=["a","b","c"]
arr.name="wayne"
arr.map(function(item,index,arr){ 
   console.log(item)
   return item
})
image.png

forEach()和 map() 相同點:
(1)只能循環(huán)遍歷數(shù)組,遍歷對象報錯forEach/map is not a function
(2)forEach() 和 map() 里面每一次執(zhí)行匿名函數(shù)都支持3個參數(shù):數(shù)組中當(dāng)前項item,當(dāng)前項的索引index,原始數(shù)組arr开呐。
(3)匿名函數(shù)中的this都是指Window烟勋。
forEach()和 map() 不同點:
(1)forEach() 沒有返回值;map() 有返回值筐付,可以return 出來卵惦。

【總結(jié)】

這么多循環(huán),肯定會有疑問瓦戚,什么時候用哪個沮尿?用哪個性能更好?
首先明確一點哪個快和應(yīng)該用哪個较解,并不應(yīng)該劃等號畜疾。如果你真的需要考慮性能,或者有 break 的需求印衔,就用 for 吧啡捶。但是如果真的到了這一步,你應(yīng)該不會對性能這個問題有所顧慮奸焙。
所以最后總結(jié)就是:
【1】遍歷對象用for...in(數(shù)組也可以用實際還是把數(shù)組當(dāng)成對象去遍歷)
【2】簡單遍歷數(shù)組用for或forEach或for of
【3】需要將數(shù)組按照某種規(guī)則映射為另一個數(shù)組就應(yīng)該用map()

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瞎暑,一起剝皮案震驚了整個濱河市彤敛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌了赌,老刑警劉巖墨榄,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異揍拆,居然都是意外死亡渠概,警方通過查閱死者的電腦和手機茶凳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門嫂拴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人贮喧,你說我怎么就攤上這事筒狠。” “怎么了箱沦?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵辩恼,是天一觀的道長。 經(jīng)常有香客問我谓形,道長灶伊,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任寒跳,我火速辦了婚禮聘萨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘童太。我一直安慰自己米辐,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布书释。 她就那樣靜靜地躺著翘贮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪爆惧。 梳的紋絲不亂的頭發(fā)上狸页,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天,我揣著相機與錄音扯再,去河邊找鬼肴捉。 笑死,一個胖子當(dāng)著我的面吹牛叔收,可吹牛的內(nèi)容都是我干的齿穗。 我是一名探鬼主播,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼饺律,長吁一口氣:“原來是場噩夢啊……” “哼窃页!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤脖卖,失蹤者是張志新(化名)和其女友劉穎乒省,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體畦木,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡袖扛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了十籍。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛆封。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖勾栗,靈堂內(nèi)的尸體忽然破棺而出惨篱,到底是詐尸還是另有隱情,我是刑警寧澤围俘,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布砸讳,位于F島的核電站,受9級特大地震影響界牡,放射性物質(zhì)發(fā)生泄漏簿寂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一宿亡、第九天 我趴在偏房一處隱蔽的房頂上張望常遂。 院中可真熱鬧,春花似錦她混、人聲如沸烈钞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽毯欣。三九已至,卻和暖如春臭脓,著一層夾襖步出監(jiān)牢的瞬間酗钞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工来累, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留砚作,地道東北人。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓嘹锁,卻偏偏與公主長得像葫录,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子领猾,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,435評論 2 359

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