亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

詳解JS中遍歷語法的比較

2019-11-19 16:54:25
字體:
來源:轉載
供稿:網友

for循環

JavaScript 提供多種遍歷語法。最原始的寫法就是for循環。

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

缺點:這種寫法比較麻煩

forEach

數組提供內置的forEach方法

let arr = [1,2,3,4,5];arr.forEach((element,index) => {  console.log(element); // 1 2 3 4 5});

缺點:這種寫法的問題在于,無法中途跳出forEach循環,break命令或return命令都不能奏效。

 for...in

for…in 用于遍歷對象所有的可枚舉屬性,功能類似于Object.keys()。 

let obj = {  name: 'cloud',  phone: '157xxxx2065'} for (let prop in obj) {  console.log(prop); // name phone}

可能有朋友會問,不可枚舉的對象有哪些呢? 比如constructor,數組的length就屬于不可枚舉屬性。

let arr = [10, 20, 30, 40, 50]; for (let prop in arr) {  console.log(prop); // '0' '1' '2' '3' '4'}

缺點:

  1. 數組的鍵名是數字,但是for...in循環是以字符串作為鍵名“0”、“1”、“2”等等。
  2. for...in循環主要是為遍歷對象而設計的,不適用于遍歷數組

 for...of

for…of是ES6新增的遍歷方式,它提供了統一的遍歷機制。所有實現了[Symbol.iterator]接口的對象都可以被遍歷。for...of循環可以使用的范圍包括數組、Set 和 Map 結構、某些類似數組的對象(比如arguments對象、DOM NodeList 對象)、Generator 對象,以及字符串

優點:

  1. 有著同for...in一樣的簡潔語法,但是沒有for...in那些缺點
  2. 不同用于forEach方法,它可以與breakcontinuereturn配合使用
  3. 提供了遍歷所有數據結構的統一操作接口

下面是一個使用break語句,跳出for...of循環的例子。

for (var n of fibonacci) { if (n > 1000)  break; console.log(n);}

上面的例子,會輸出斐波納契數列小于等于1000的項。如果當前項大于1000,就會使用break語句跳出for...of循環。

 for...of獲取索引

  1. entries() 返回一個遍歷器對象,用來遍歷[鍵名, 鍵值]組成的數組。對于數組,鍵名就是索引值;對于 Set,鍵名與鍵值相同。Map 結構的 Iterator 接口,默認就是調用entries方法。
  2. keys() 返回一個遍歷器對象,用來遍歷所有的鍵名。
  3. values() 返回一個遍歷器對象,用來遍歷所有的鍵值。
 // demolet arr = ['a', 'b', 'c'];for (let pair of arr.entries()) { console.log(pair);}// [0, 'a']// [1, 'b']// [2, 'c']

類似數組的對象

類似數組的對象包括好幾類。下面是for...of循環用于字符串、DOM NodeList 對象、arguments對象的例子。

// 字符串let str = "hello";for (let s of str) { console.log(s); // h e l l o}// DOM NodeList對象let paras = document.querySelectorAll("p");for (let p of paras) { p.classList.add("test");}// arguments對象function printArgs() { for (let x of arguments) {  console.log(x); }}printArgs('a', 'b');// 'a'// 'b'

并不是所有類似數組的對象都具有 Iterator 接口,一個簡便的解決方法,就是使用Array.from方法將其轉為數組。 

let arrayLike = { length: 2, 0: 'a', 1: 'b' };// 報錯for (let x of arrayLike) { console.log(x);}// 正確for (let x of Array.from(arrayLike)) { console.log(x); // 'a' // 'b'}

普通的對象

對于普通的對象,for...of結構不能直接使用,會報錯,必須部署了 Iterator 接口后才能使用。

let es6 = { edition: 6, committee: "TC39", standard: "ECMA-262"};for (let e in es6) { console.log(e);}// edition// committee// standardfor (let e of es6) { console.log(e);}// TypeError: es6 is not iterable

解決方法是,使用Object.keys方法將對象的鍵名生成一個數組,然后遍歷這個數組。

for (var key of Object.keys(someObject)) { console.log(key + ': ' + someObject[key]);}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩av综合中文字幕| 亚洲天堂第二页| 一道本无吗dⅴd在线播放一区| 91久久中文字幕| 在线观看国产成人av片| 亚洲精品中文字幕有码专区| 国产丝袜一区二区| 91中文在线视频| 欧美性极品xxxx娇小| 久久国产精品久久国产精品| 欧美精品亚州精品| 日韩成人av一区| 久久理论片午夜琪琪电影网| 2021久久精品国产99国产精品| 欧美视频第一页| 一本色道久久综合狠狠躁篇的优点| 精品福利在线视频| 午夜精品久久久久久久99黑人| 日韩国产在线看| 亚洲韩国欧洲国产日产av| 国产精品免费看久久久香蕉| 亚洲午夜av电影| 国产精品第一区| 国产精品永久在线| 亚洲色图偷窥自拍| 日韩色av导航| 欧美日韩亚洲一区二区| 精品小视频在线| 国产区精品视频| 色在人av网站天堂精品| 91麻豆国产语对白在线观看| 久久免费视频网站| 国产999精品久久久影片官网| 午夜美女久久久久爽久久| 在线成人免费网站| 欧美亚洲另类制服自拍| 久久久久在线观看| 日韩中文字幕久久| 国产在线播放不卡| 日韩av网站导航| 欧美丝袜第一区| 国产成人精品综合久久久| 中文字幕精品一区二区精品| 久久精品亚洲94久久精品| 午夜精品久久久久久久99黑人| 欧洲亚洲免费在线| 久久中文字幕一区| 久久婷婷国产麻豆91天堂| 日韩毛片在线观看| 91精品啪aⅴ在线观看国产| 久久久成人精品视频| 欧美小视频在线| 91久久精品日日躁夜夜躁国产| 国语自产精品视频在线看抢先版图片| 欧美在线性爱视频| 91综合免费在线| 欧美视频一二三| 精品国产欧美一区二区三区成人| 538国产精品一区二区在线| 97精品视频在线观看| 91在线无精精品一区二区| 久久露脸国产精品| 国产999精品视频| 人人澡人人澡人人看欧美| 伊人精品在线观看| 国产欧美精品一区二区三区介绍| 川上优av一区二区线观看| 日韩在线视频线视频免费网站| 亚洲日本中文字幕| 成人有码视频在线播放| 久久中文字幕在线视频| 亚洲精品电影网| 久久天天躁狠狠躁夜夜av| 中文字幕欧美日韩在线| 亚洲第一男人av| 亚洲成人精品在线| 亚洲在线观看视频网站| 欧美寡妇偷汉性猛交| 日韩中文字幕免费| 亚洲а∨天堂久久精品9966| 日韩不卡中文字幕| 黄网动漫久久久| 国产精品视频一区二区三区四| 国产精品女主播| 91嫩草在线视频| 视频一区视频二区国产精品| 日韩欧美亚洲综合| 91精品国产自产在线| 成人激情视频在线| 97在线观看免费| 日韩亚洲欧美中文高清在线| 久久亚洲电影天堂| 成人久久一区二区三区| 亚洲另类图片色| 亚洲欧洲日产国码av系列天堂| 日本高清不卡的在线| 久久久久一本一区二区青青蜜月| 亚洲天堂av图片| 亚洲人成亚洲人成在线观看| 亚洲视频自拍偷拍| 国产精品入口夜色视频大尺度| 在线精品国产成人综合| 成人在线一区二区| 久久中文字幕视频| 韩国国内大量揄拍精品视频| 久久夜色撩人精品| 欧美最猛性xxxxx亚洲精品| 国产精品视频大全| 欧美精品电影免费在线观看| 欧美日韩精品国产| 欧美精品成人在线| 欧美成人一区在线| 91视频九色网站| 国产视频999| 国产欧美精品一区二区三区-老狼| 欧美激情乱人伦| 色偷偷亚洲男人天堂| 欧美成人午夜影院| 亚洲国产欧美在线成人app| 91av免费观看91av精品在线| 亚洲国产另类 国产精品国产免费| 欧美床上激情在线观看| 亚洲电影免费观看高清完整版| 欧美国产日韩二区| 久久久久久久成人| 亚洲jizzjizz日本少妇| 亚洲色图在线观看| 精品日本美女福利在线观看| 久久91精品国产91久久久| 国产精品国产福利国产秒拍| 欧美日韩黄色大片| 欧美午夜丰满在线18影院| 日韩男女性生活视频| 欧美资源在线观看| 欧美专区在线播放| 亚洲午夜国产成人av电影男同| 精品欧美激情精品一区| 日韩av影视在线| 一本色道久久88综合亚洲精品ⅰ| 国产精品久久久久av| 久久中文字幕在线视频| 欧美极品第一页| 欧美刺激性大交免费视频| 性欧美在线看片a免费观看| 久久视频中文字幕| 性色av一区二区咪爱| 九九热这里只有精品免费看| 国产视频久久久久| 国产精品国产福利国产秒拍| 欧美精品一区在线播放| 久久在线视频在线| 国产一区二区三区四区福利| 久久影视电视剧凤归四时歌| 亚洲视频在线观看网站| 亚洲精品日韩丝袜精品| 欧美大片在线影院| 97人人做人人爱| 51精品国产黑色丝袜高跟鞋| 欧美精品在线第一页| 青青草一区二区| 欧美激情视频一区二区三区不卡| 成人天堂噜噜噜| 91夜夜未满十八勿入爽爽影院| 在线观看久久久久久|